#include #define rep(i,a,b) for(int i=a;i> N >> A; rep(i, 0, A) cin >> B[i]; cin >> C; rep(i, 0, C) cin >> D[i]; int cntA = A, cntC = C; int usedA[50], usedC[50]; rep(i, 0, 50) usedA[i] = usedC[i] = 0; int ans = 0; rep(i, 0, N) { int ma = 0; rep(i, 0, A) if (!usedA[i]) ma = max(ma, B[i]); int mi = 1010; rep(i, 0, C) if (!usedC[i]) mi = min(mi, D[i]); if (mi < ma) { ans++; rep(i, 0, A) if (!usedA[i] && B[i] == ma) { usedA[i] = 1; cntA--; break; } rep(i, 0, C) if (!usedC[i] && D[i] == mi) { usedC[i] = 1; cntC--; break; } } else { mi = 1010; rep(i, 0, A) if (!usedA[i]) mi = min(mi, B[i]); ma = 0; rep(i, 0, C) if (!usedC[i]) ma = max(ma, D[i]); rep(i, 0, A) if (!usedA[i] && B[i] == mi) { usedA[i] = 1; cntA--; break; } rep(i, 0, C) if (!usedC[i] && D[i] == ma) { usedC[i] = 1; cntC--; break; } } if (cntA == 0) { cntA = A; rep(i, 0, A) usedA[i] = 0; } if (cntC == 0) { cntC = C; rep(i, 0, C) usedC[i] = 0; } } cout << ans << endl; }