# | 제출 시각UTC-0 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1051209 | Trent | 수천개의 섬 (IOI22_islands) | C++17 | 24 ms | 6492 KiB |
이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "islands.h"
#include "bits/stdc++.h"
using namespace std;
#define forR(i, x) for(int i = 0; i < (x); ++i)
#define REP(i, a, b) for(int i = (a); i < (b); ++i)
#define all(x) x.begin(), x.end()
typedef long long ll;
typedef vector<int> vi;
typedef vector<vi> vvi;
typedef vector<ll> vll;
typedef vector<bool> vb;
struct edge{int t, i;};
vector<vector<edge>> adj;
vi nStk, eStk;
vb vis;
bool dfs(int c, vi& ans) {
// nStk is [0, c), eStk is [0, c]
if(adj[c].size() > 2) {
for(int i : eStk) ans.push_back(i);
vi use;
forR(i, 3) if(adj[c][i].t != nStk.back()) use.push_back(adj[c][i].i);
int a=use[0], b=use[1];
vector<int> toAdd = {a, a ^ 1, b, b ^ 1, a ^ 1, a, b ^ 1, b};
for(int i : toAdd) ans.push_back(i);
for(int i = (int) eStk.size() - 1; i >= 0; --i) ans.push_back(eStk[i]);
return true;
}
vis[c] = true;
nStk.push_back(c);
# | 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... |