#include #include #include using namespace std; struct d{ int l,b; bool operator==(const d a) const { return l==a.l && b==a.b; } bool operator<(const d a) const { if(l == a.l){ return b < a.b; } return l < a.l; } bool operator>(const d a) const { return !(*this == a || *this < a); } }; int main(){ int n;cin>>n; priority_queue,greater> A; vector B(n); for(int i = 0; n > i; i++){ cin>>B[i]; } vector C(n); for(int i = 0; n > i; i++){ cin>>C[i]; } int ans = n; for(int i = 0; n > i; i++){ for(int j = 0; n > j; j++){ A.push({B[j],0}); } for(int j = 0; n > j; j++){ auto z = A.top();A.pop(); z.l += C[(i+j)%n]/2; z.b++; A.push(z); } int tmp = 0; while(A.size()){ auto z = A.top();A.pop(); tmp = max(tmp,z.b); } ans = min(ans,tmp); } cout << ans << endl; }