제출 #1076529

#제출 시각아이디문제언어결과실행 시간메모리
1076529Ignut수천개의 섬 (IOI22_islands)C++17
26 / 100
108 ms25468 KiB
/* 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; }

컴파일 시 표준 에러 (stderr) 메시지

islands.cpp: In function 'std::variant<bool, std::vector<int, std::allocator<int> > > find_journey(int, int, std::vector<int>, std::vector<int>)':
islands.cpp:76:31: warning: division by zero [-Wdiv-by-zero]
   76 |     if (X == -1 || Y == -1) n /= 0;
      |                             ~~^~~~
islands.cpp:81:33: warning: division by zero [-Wdiv-by-zero]
   81 |     if (!idx.count({lst, X})) n /= 0;
      |                               ~~^~~~
islands.cpp:82:33: warning: division by zero [-Wdiv-by-zero]
   82 |     if (!idx.count({lst, Y})) n /= 0;
      |                               ~~^~~~
islands.cpp:83:33: warning: division by zero [-Wdiv-by-zero]
   83 |     if (!idx.count({Y, lst})) n /= 0;
      |                               ~~^~~~
islands.cpp:84:33: warning: division by zero [-Wdiv-by-zero]
   84 |     if (!idx.count({X, lst})) n /= 0;
      |                               ~~^~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...