이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "rect.h"
long long count_rectangles(std::vector<std::vector<int> > a) {
int N = a.size();
int M = a[0].size();
long long ans = 0;
if (N == 3) {
bool works[M];
works[0] = false;
works[M - 1] = false;
for (int i = 1; i < M - 1; ++i) {
works[i] = a[1][i] < a[0][i] && a[1][i] < a[2][i];
}
for (int l = 1; l < M - 1; ++l) {
if (!works[l]) continue;
int max = a[1][l];
for (int r = l; r < M - 1; ++r) {
if (!works[r]) break;
max = std::max(max, a[1][r]);
if (max >= a[1][l - 1]) break;
if (max >= a[1][r + 1]) continue;
ans++;
}
}
return ans;
}
int max[N];
for (int u = 1; u < N - 1; ++u) {
int maxc[M];
for (int i = 0; i < M; ++i) {
maxc[i] = a[u][i];
}
std::vector<int> alive;
for (int i = 1; i < M - 1; ++i) {
alive.push_back(i);
}
for (int d = u; d < N - 1; ++d) {
for (auto i: alive) {
maxc[i] = std::max(maxc[i], a[d][i]);
}
bool works[M];
std::vector<int> working, nextalive;
for (int i = 0; i < M; ++i) {
works[i] = maxc[i] < a[u - 1][i] && maxc[i] < a[d + 1][i];
if (works[i]) working.push_back(i);
if (maxc[i] < a[u - 1][i]) nextalive.push_back(i);
}
alive = nextalive;
for (auto l: working) {
for (int i = u; i <= d; ++i) {
max[i] = a[i][l];
}
for (int r = l; r < M - 1; ++r) {
if (!works[r]) break;
for (int i = u; i <= d; ++i) {
max[i] = std::max(max[i], a[i][r]);
}
for (int i = u; i <= d; ++i) {
if (max[i] >= a[i][l - 1]) goto dead;
}
for (int i = u; i <= d; ++i) {
if (max[i] >= a[i][r + 1]) goto next;
}
ans++;
next:;
}
dead:;
}
}
}
return ans;
}
# | 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... |