Submission #842649

#TimeUsernameProblemLanguageResultExecution timeMemory
842649andrei_c1Soccer Stadium (IOI23_soccer)C++17
6 / 100
240 ms31788 KiB
#include "soccer.h" #include <bits/stdc++.h> using namespace std; using pii = pair<int, int>; const int ASC = 0; const int DESC = 1; const int CACA = -1; void minSelf(int &x, int y) { if(y < x) { x = y; } } void maxSelf(int &x, int y) { if(y > x) { x = y; } } // a before b int trend(const pii &a, const pii &b) { if(a.first >= b.first && a.second <= b.second) { return ASC; } if(a.first <= b.first && a.second >= b.second) { return DESC; } return CACA; } int biggest_stadium(int n, std::vector<std::vector<int>> v) { int x = -1, y = -1, cnt = 0; for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) { if(v[i][j] == 1) { cnt++; x = i; y = j; } } } if(cnt == 1) { return n * n - min({(x + 1) * (y + 1), (x + 1) * (n - y), (n - x) * (y + 1), (n - x) * (n - y)}); } else if(cnt == 0) { return n * n; } vector<vector<pii>> intervals; for(int i = 0; i < n; i++) { intervals.emplace_back(vector<pii>(0)); int lst = -1; for(int j = 0; j < n; j++) { if(v[i][j] == 0 && lst == -1) { lst = j; } else if(v[i][j] == 1 && lst != -1) { intervals.back().emplace_back(lst, j - 1); lst = -1; } } if(lst != -1) { intervals.back().emplace_back(lst, n - 1); } if(intervals.back().empty()) { intervals.pop_back(); } } if(false) { return 0; } else { assert(!intervals.empty()); for(const auto &row: intervals) { if(row.size() > 1) { return 0; } } for(int i = 1; i < (int) intervals.size(); i++) { for(int j = 0; j < i; j++) { if(trend(intervals[i][0], intervals[j][0]) == -1) { return 0; } } } int lst = ASC; pair<int, int> in = intervals[0][0]; for(int i = 1; i < (int) intervals.size(); i++) { maxSelf(in.first, intervals[i][0].first); minSelf(in.second, intervals[i][0].second); if(in.first > in.second) { return 0; } int crt = trend(intervals[i - 1][0], intervals[i][0]); if(crt == CACA) { return 0; } if(lst == ASC && crt == DESC) { lst = DESC; } else if(lst == DESC && crt == ASC) { return 0; } } return n * n - cnt; } return 0; } /* 5 1 1 0 1 1 1 0 0 0 1 1 0 0 1 1 1 0 1 1 1 1 1 1 1 1 ------------ 5 1 1 0 1 1 1 0 0 0 1 1 0 0 1 1 1 1 0 1 1 1 1 1 1 1 ------------ 3 0 0 1 0 0 0 1 0 0 */ /* [-----] [--------] [-------------] [---] */
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...