blob: 86c4cf2e53bacc816c4f1b5238f35a15b783f200 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
|
#include <vector>
using std::vector;
#include <iterator>
#include <limits>
#include <numeric>
class Solution {
public:
long long gridGame(vector<vector<int>> &grid) {
int s = grid.front().size();
std::vector<long long> row0(grid[0].cbegin(), grid[0].cend());
std::vector<long long> row1(grid[1].cbegin(), grid[1].cend());
std::vector<long long> ps0, ps1;
std::partial_sum(row0.cbegin(), row0.cend(), std::back_inserter(ps0));
std::partial_sum(row1.cbegin(), row1.cend(), std::back_inserter(ps1));
long long r = std::numeric_limits<long long>::max();
for (int i = 0; i < s; i++) {
long long c = std::max(ps0.back() - ps0[i], i ? ps1[i - 1] : 0);
r = std::min(r, c);
}
return r;
}
};
|