|
| 1 | +let input = '' |
| 2 | + |
| 3 | +process.stdin.on('data', data => input += data) |
| 4 | +process.stdin.on('end', () => { |
| 5 | + const lines = input.split('\n') |
| 6 | + const [t] = lines[0].split(' ').map(Number) |
| 7 | + for (let kase = 0; kase < t; kase++) { |
| 8 | + const [n] = lines[kase * 5 + 1].split(' ').map(Number) |
| 9 | + const a = lines[kase * 5 + 2].split(' ').map(Number) |
| 10 | + const [m] = lines[kase * 5 + 3].split(' ').map(Number) |
| 11 | + const b = lines[kase * 5 + 4].split(' ').map(Number) |
| 12 | + const [k] = lines[kase * 5 + 5].split(' ').map(Number) |
| 13 | + // console.log(`Case #${kase + 1}`, n, a, m, b, k) |
| 14 | + // f[i]: 从 a 里面选 i 个数的最大 |
| 15 | + const f = Array(n + 1).fill(0) |
| 16 | + let sum = Array(n + 1).fill(0) |
| 17 | + for (let i = 0; i < n; i++) sum[i + 1] = sum[i] + a[i] |
| 18 | + for (let i = 0; i <= n; i++) { |
| 19 | + // 从左侧选 j 个数 |
| 20 | + for (let j = 0; j <= i; j++) { |
| 21 | + const k = i - j |
| 22 | + // [0, j-1], [n-k, n-1] |
| 23 | + f[i] = Math.max(f[i], sum[j] + sum[n] - sum[n - k]) |
| 24 | + } |
| 25 | + } |
| 26 | + |
| 27 | + const g = Array(m + 1).fill(0) |
| 28 | + sum = Array(m + 1).fill(0) |
| 29 | + for (let i = 0; i < m; i++) sum[i + 1] = sum[i] + b[i] |
| 30 | + for (let i = 0; i <= m; i++) { |
| 31 | + // 从左侧选 j 个数 |
| 32 | + for (let j = 0; j <= i; j++) { |
| 33 | + const k = i - j |
| 34 | + // [0, j-1], [n-k, n-1] |
| 35 | + g[i] = Math.max(g[i], sum[j] + sum[m] - sum[m - k]) |
| 36 | + } |
| 37 | + } |
| 38 | + |
| 39 | + let ans = 0 |
| 40 | + for (let i = 0; i <= Math.min(k, n); i++) { |
| 41 | + if (k - i < 0 || k - i > m) continue |
| 42 | + ans = Math.max(ans, f[i] + g[k - i]) |
| 43 | + } |
| 44 | + |
| 45 | + console.log(`Case #${kase + 1}: ${ans}`) |
| 46 | + } |
| 47 | +}) |
0 commit comments