diff options
| author | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-30 00:18:17 +0200 |
|---|---|---|
| committer | Omar Magdy <omar.professional8777@gmail.com> | 2022-05-30 00:18:17 +0200 |
| commit | 3a89fc707253f75f46fd5a4822817f1fd5156c40 (patch) | |
| tree | 474b08b187895af91c10838aae21142b2ba2514d /contests/Round#790/10-10-2022(Div4)/D | |
| parent | f5ff62a26052f084b6b807cba220c86785fd45e3 (diff) | |
| download | competitive-programming-3a89fc707253f75f46fd5a4822817f1fd5156c40.tar.xz competitive-programming-3a89fc707253f75f46fd5a4822817f1fd5156c40.zip | |
Made that every problem is its own folder to make building the code a smooth operation with a shortcut
Diffstat (limited to 'contests/Round#790/10-10-2022(Div4)/D')
| -rw-r--r-- | contests/Round#790/10-10-2022(Div4)/D/D.cpp | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/contests/Round#790/10-10-2022(Div4)/D/D.cpp b/contests/Round#790/10-10-2022(Div4)/D/D.cpp new file mode 100644 index 0000000..6ee775c --- /dev/null +++ b/contests/Round#790/10-10-2022(Div4)/D/D.cpp @@ -0,0 +1,51 @@ +#include<bits/stdc++.h> + +using namespace std; + +int main () { + int tt; + cin >> tt; + while(tt--) { + int r, c; + cin >> r >> c; + vector<vector<int>> grid(r, vector<int>(c)); + for(auto &v : grid) { + for(auto &x : v){ + cin >> x; + } + } + vector<int> res; + int ans = 0; + for(int i = 0; i < r; i++) { + for(int j = 0; j < c; j++) { + ans += grid[i][j]; + int r1 = i, r2 = i, r3 = i, r4 = i; + int c1 = j, c2 = j, c3 = j, c4 =j; + while(r1+1 <= r - 1 && c1 + 1 <= c - 1) { + r1++; + c1++; + ans+= grid[r1][c1]; + } + while(r2+1 <= r - 1 && c2 - 1 >= 0) { + r2++; + c2--; + ans+= grid[r2][c2]; + } + while(r3-1 >= 0 && c3 + 1 <= c - 1) { + r3--; + c3++; + ans+= grid[r3][c3]; + } + while(r4-1 >= 0 && c4 - 1 >= 0) { + r4--; + c4--; + ans+= grid[r4][c4]; + cout << "r4 " << r4 << " c4 " << c4 << endl; + } + res.push_back(ans); + ans = 0; + } + } + cout << *max_element(res.begin(), res.end()) << endl; + } +} |
