이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "rect.h"
//Challenge: Accepted
#include <bits/stdc++.h>
#pragma GCC optimize("Ofast")
using namespace std;
#ifdef zisk
void debug(){cout << endl;}
template<class T, class ... U> void debug(T a, U ... b){cout << a << " ", debug(b...);}
template<class T> void pary(T l, T r) {
while (l != r) cout << *l << " ", l++;
cout << endl;
}
#else
#define debug(...) 0
#define pary(...) 0
#endif
#define ll long long
#define maxn 200005
#define mod 1000000007
#define pii pair<int, int>
#define ff first
#define ss second
#define io ios_base::sync_with_stdio(0);cin.tie(0);
int dir[4][2] = {{1, 0}, {-1, 0}, {0, 1}, {0, -1}};
long long count_rectangles(std::vector<std::vector<int> > a) {
int n = a.size(), m = a[0].size();
vector<vector<bool> > vis(n, vector<bool>(m, 0));
ll ret = 0;
for (int i = 1;i < n-1;i++) {
for (int j = 1;j < m-1;j++) {
if (!vis[i][j] && a[i][j] == 0) {
//debug(i, j);
queue<pii> que;
bool good = 1;
que.push({i, j});
int cnt = 0;
int xmin = i, xmax = i, ymin = j, ymax = j;
while (que.size()) {
pii cur = que.front();que.pop();
vis[cur.ff][cur.ss] = 1;
cnt++;
xmin = min(xmin, cur.ff);
xmax = max(xmax, cur.ff);
ymin = min(ymin, cur.ss);
ymax = max(ymax, cur.ss);
for (int d = 0;d < 4;d++) {
int nx = cur.ff + dir[d][0], ny = cur.ss + dir[d][1];
if (!vis[nx][ny] && a[nx][ny] == 0) {
if (nx <= 0 || nx >= n - 1 || ny <= 0 || ny >= m - 1) {
good = 0;
} else {
vis[nx][ny] = 1;
que.push({nx, ny});
}
}
}
}
debug(i, j, cnt, (xmax - xmin+1) * (ymax - ymin+1));
if (cnt == (xmax - xmin+1) * (ymax - ymin+1) && good) {
ret++;
}
}
}
}
return ret;
}
컴파일 시 표준 에러 (stderr) 메시지
rect.cpp: In function 'long long int count_rectangles(std::vector<std::vector<int> >)':
rect.cpp:14:20: warning: statement has no effect [-Wunused-value]
14 | #define debug(...) 0
| ^
rect.cpp:59:5: note: in expansion of macro 'debug'
59 | debug(i, j, cnt, (xmax - xmin+1) * (ymax - ymin+1));
| ^~~~~
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |