# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
1076529 | Ignut | Thousands Islands (IOI22_islands) | C++17 | 108 ms | 25468 KiB |
This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/* Ignut
started: 11.08.2024
now: 26.08.2024
████████████████████████████████████████████████████████████████████
████████████████████████████████ ████████████████████████████████
██████████████████████████████ ██████████████████████████████
██████ ██████████████████ ██████████████████ ██████
██████ ██████████████ ██████████████ ██████
██████ ██ ████████████ ████████████ ██ ██████
██████ ████ ██████████ ██████████ ████ ██████
██████ ████ ██████████ ██████████ ████ ██████
██████ ████ ██████████ ██████████ ██████ ██████
██████ ██████ ██████████ ██████████ ██████ ██████
██████ ██████ ████████ ████████ ██████ ██████
██████ ██████ ██████ ██████ ██████ ██████
██████ ████ ████ ████ ████ ██████
██████ ██████████ ████ ██████████ ██████
██████ ██ ██████ ████████ ██████ ██ ██████
██████ ██████ ████████ ██████ ██████
██████ ██ ██ ██████
██████████████████████ ████ ████ ██████████████████████
████████████████████████ ██ ██ ████████████████████████
██████████████████████████ ██████████████████████████
██████████████████████████████ ██████████████████████████████
████████████████████████████████████████████████████████████████████
*/
#include <bits/stdc++.h>
using namespace std;
using ll = long long;
const int MAXN = 1e5 + 123;
int n;
vector<pair<int, int>> g[MAXN];
vector<int> order;
bool ans = false;
int lst = -1;
int X = -1, Y = -1;
void dfs(int v, int prev) {
if (ans) return;
if ((v == 0) + g[v].size() >= 3) {
lst = v;
ans = true;
for (auto [to, e] : g[v]) {
if (to == prev) continue;
if (X == -1) X = to;
else if (Y == -1) Y = to;
}
return;
}
for (auto [to, e] : g[v]) {
if (to == prev) continue;
order.push_back(e);
dfs(to, v);
}
}
int cnt[MAXN] = {};
variant<bool, vector<int>> find_journey(int N, int M, vector<int> U, vector<int> V) {
n = N;
map<pair<int, int>, vector<int>> idx;
for (int i = 0; i < M; i ++) {
g[U[i]].push_back({V[i], i});
// g[V[i]].push_back(U[i]);
idx[{U[i], V[i]}].push_back(i);
}
dfs(0, -1);
if (!ans) return false;
if (X == -1 || Y == -1) n /= 0;
// if (!order.empty()) n /= 0;
vector<int> res = order;
if (!idx.count({lst, X})) n /= 0;
if (!idx.count({lst, Y})) n /= 0;
if (!idx.count({Y, lst})) n /= 0;
if (!idx.count({X, lst})) n /= 0;
int A = idx[{lst, X}].front();
int B = idx[{X, lst}].front();
int C = idx[{lst, Y}].back();
int D = idx[{Y, lst}].back();
res.push_back(A);
res.push_back(B);
res.push_back(C);
res.push_back(D);
res.push_back(B);
res.push_back(A);
res.push_back(D);
res.push_back(C);
while (!order.empty()) {
res.push_back(order.back());
order.pop_back();
}
return res;
}
Compilation message (stderr)
# | 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... |