#include #include #include #include #include #include #include #include #include #include #include #include #include #include #include using namespace std; using ll = long long; using vi = vector; using vvi = vector; using vl = vector; using vvl = vector; using vb = vector; using vvb = vector; using vd = vector; using vs = vector; using pii = pair; using pll = pair; using pdd = pair; using vpii = vector; using vpll = vector; using vpdd = vector; const int inf = (1 << 30) - 1; const ll INF = 1LL << 60; //const int MOD = 1000000007; const int MOD = 998244353; int main() { int n; cin >> n; vi a(n), b(n * 2); priority_queue, greater> pq_s; for (int i = 0; i < n; i++) { cin >> a[i]; pq_s.push({ a[i], 0 }); } for (int i = 0; i < n; i++) { cin >> b[i]; b[i + n] = b[i]; } int ans = inf; for (int i = 0; i < n; i++) { priority_queue, greater> pq = pq_s; int x = 0; for (int j = 0; j < n; j++) { pii p = pq.top(); pq.pop(); p.second++; x = max(x, p.second); p.first += b[i + j] / 2; pq.push(p); } ans = min(ans, x); } cout << ans << endl; return 0; }