# | 제출 시각UTC-0 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
291138 | AlexPop28 | 섬 항해 (CEOI13_adriatic) | C++11 | 449 ms | 129528 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define dbg() cerr <<
#define name(x) (#x) << ": " << (x) << ' ' <<
using namespace std;
const int N = 2500;
template<class T> void Max(T &a, const T &b) { a = max(a, b); }
template<class T> void Min(T &a, const T &b) { a = min(a, b); }
void MakePrefix(vector<vector<int>> &a) {
int n = a.size(), m = a[0].size();
for (int i = 0; i < n; ++i) {
for (int j = 0; j < m; ++j) {
if (i - 1 >= 0) a[i][j] += a[i - 1][j];
if (j - 1 >= 0) a[i][j] += a[i][j - 1];
if (i - 1 >= 0 && j - 1 >= 0) a[i][j] -= a[i - 1][j - 1];
}
}
}
vector<vector<int>> Solve(const vector<vector<int>> &pos) {
int n = pos.size(), m = pos[0].size();
vector<int> up(m, n), rgt(n, -1);
for (int j = 0; j < m; ++j) {
if (j != 0) up[j] = up[j - 1];
for (int i = 0; i < up[j]; ++i) {
if (pos[i][j]) {
up[j] = i;
# | 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... |