Submission #295187

#TimeUsernameProblemLanguageResultExecution timeMemory
295187theStaticMindRectangles (IOI19_rect)C++14
13 / 100
1002 ms505592 KiB
#include <bits/stdc++.h> #include "rect.h" using namespace std; int n, m; bool vis[2500][2500]; void dfs(int x, int y, map<int, int>& R, map<int, int>& C){ vis[x][y] = true; R[x]++; C[y]++; if(x+1<n && !vis[x+1][y]) dfs(x+1, y,R,C); if(x-1>=0 && !vis[x-1][y]) dfs(x-1, y,R,C); if(y+1<m && !vis[x][y+1]) dfs(x, y+1, R,C); if(y-1>=0 && !vis[x][y-1]) dfs(x, y-1,R,C); } long long count_rectangles(std::vector<std::vector<int> > a) { n = a.size(); m = a[0].size(); long long cnt = 0; for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ vis[i][j] = a[i][j]; } } for(int i = 0; i < n; i++){ for(int j = 0; j < m; j++){ if(vis[i][j]) continue; bool yes = true; map<int,int>R,C; dfs(i, j, R, C); for(auto itr : R){ yes &= (itr.second == R.begin()->second); } for(auto itr : C){ yes &= (itr.second == C.begin()->second); } yes &= !R.count(0); yes &= !R.count(n - 1); yes &= !C.count(0); yes &= !C.count(m - 1); if(yes) cnt++; } } return cnt; }
#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...