이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
#define N 500005
using namespace std;
int vis[N], p[N];
int n, m, pre;
set<int> adj[N];
vector<vector<int> > answer;
vector<int> ans;
int main(){
ios_base::sync_with_stdio(0);
cin.tie(0);
cout.tie(0);
cin >> n >> m;
for(int i = 1; i <= m; i++){
int a, b;
cin >> a >> b;
adj[a].insert(b);
adj[b].insert(a);
}
for(int i = 1; i <= n; i++){
while(adj[i].size()){
stack<int> s;
s.push(i);
while(s.size()){
int now = s.top();
// cout << now << ' ';
if(vis[now] == 1){
// cout << 1 << '\n';
ans.push_back(now);
s.pop();
while(s.top() != now){
vis[s.top()] = 0;
ans.push_back(s.top());
s.pop();
}
vis[now] = 0;
answer.push_back(ans);
ans.clear();
}
else{
if(adj[now].size() == 0){
vis[now] = 2;
s.pop();
// cout << 2 << '\n';
}
else{
// cout << 3 << '\n';
vis[now] = 1;
int k = *adj[now].begin();
adj[now].erase(k);
adj[k].erase(now);
s.push(k);
}
}
}
}
}
for(vector<int> v : answer){
for(int k : v){
cout << k << ' ';
}
cout << '\n';
}
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |