Submission #541644

#TimeUsernameProblemLanguageResultExecution timeMemory
541644rainliofficialPotemkin cycle (CEOI15_indcyc)C++17
70 / 100
611 ms59136 KiB
#include <bits/stdc++.h> using namespace std; #define ll long long #define pii pair<int, int> #define sz(x) (int)x.size() #define f first #define s second struct edge{ int from, to; }; const int MAXN = 1005, MAXR = 2e5+5; edge allEdges[MAXR]; vector<int> edgeGraph[MAXR], cycle; int connected[MAXN][MAXN]; bool vis[MAXN][MAXN], on_stack[MAXR], vis2[MAXR]; // int vis2[MAXR]; int n, r; void dfs(int at, int pv){ vis[at][pv] = true; // connect all possible edges for (int i=0; i<n; i++){ if (pv != n && i != at && i != pv && connected[at][i] && !connected[i][pv]){ assert(connected[pv][at] != 0); edgeGraph[connected[pv][at]].push_back(connected[at][i]); } } for (int i=0; i<n; i++){ if (connected[at][i] && !vis[i][at]){ dfs(i, at); } } } bool dfs2(int n) { vis2[n] = on_stack[n] = true; for (int u : edgeGraph[n]) { if(on_stack[u]) { cycle.push_back(n); // start cycle on_stack[n] = on_stack[u] = false; return true; }else if(!vis2[u]) { if(dfs2(u)) { // continue cycle if(on_stack[n]) { cycle.push_back(n); on_stack[n] = false; return true; } else { // found u again cycle.push_back(n); return false; } } if(!cycle.empty()) // finished with cycle return false; } } on_stack[n] = false; return false; } int main(){ cin.tie(0); ios_base::sync_with_stdio(0); // freopen("file.in", "r", stdin); // freopen("file.out", "w", stdout); cin >> n >> r; for (int i=0; i<r; i++){ int a, b; cin >> a >> b; a--; b--; allEdges[2*i+1] = {a, b}; allEdges[2*i+2] = {b, a}; connected[a][b] = 2*i+1; connected[b][a] = 2*i+2; } dfs(0, n); dfs2(1); if (cycle.empty()) dfs2(2); if (cycle.empty()){ cout << "no" << "\n"; return 0; } reverse(cycle.begin(), cycle.end()); vector<int> ans; for (int i=0; i<sz(cycle)-1; i++){ if (i == 0){ cout << allEdges[cycle[i]].from+1 << " "; } cout << allEdges[cycle[i]].to+1 << " "; } }
#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...
#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...