Submission #538346

#TimeUsernameProblemLanguageResultExecution timeMemory
538346FatihSolakPotemkin cycle (CEOI15_indcyc)C++17
90 / 100
387 ms10604 KiB
#include <bits/stdc++.h> #define N 1005 using namespace std; int vis[N][N]; bool adj[N][N]; int par[N][N]; int n; void dfs(int a,int b){ vis[a][b] = 1; //cout << a << " " << b << endl; for(int i=1;i<=n;i++){ if(i != a && adj[b][i] && !adj[a][i]){ if(vis[b][i] == 1){ vector<int> nodes; int st = b; nodes.push_back(b); nodes.push_back(a); while(par[a][b] != st && par[a][b]){ nodes.push_back(par[a][b]); int tmp = b; b = a; a = par[a][tmp]; } for(auto u:nodes){ cout << u << " "; } exit(0); } else if(!vis[b][i]){ par[b][i] = a; dfs(b,i); } } } vis[a][b] = 2; } void solve(){ int m; cin >> n >> m; vector<pair<int,int>> edges; for(int i=1;i<=m;i++){ int a,b; cin >> a >> b; adj[a][b] = adj[b][a] = 1; edges.push_back({a,b}); edges.push_back({b,a}); } for(auto u:edges){ if(!vis[u.first][u.second]){ dfs(u.first,u.second); } } cout << "no"; } int main(){ ios_base::sync_with_stdio(false); cin.tie(nullptr); #ifdef Local freopen("in.txt","r",stdin); freopen("out.txt","w",stdout); #endif int t = 1; //cin >> t; while(t--){ solve(); } #ifdef Local cout << endl << fixed << setprecision(2) << 1000.0 * clock() / CLOCKS_PER_SEC << " milliseconds."; #endif } /* 14 15 1 2 2 3 3 4 4 5 5 6 6 7 7 8 8 9 9 10 10 11 11 12 12 13 13 14 14 1 4 11 */
#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...