# | 제출 시각 | 아이디 | 문제 | 언어 | 결과 | 실행 시간 | 메모리 |
---|---|---|---|---|---|---|---|
1114595 | 2024-11-19T08:27:24 Z | vjudge1 | Newspapers (CEOI21_newspapers) | C++17 | 2 ms | 508 KB |
#include<bits/stdc++.h> using namespace std; #define int long long #define pb push_back using pii=pair<int,int>; int parent[5000]; int find(int i){ if(parent[i]==i)return i; return parent[i]=find(parent[i]); } int unite(int i,int j){ i=find(i);j=find(j); if(i==j)return 1; parent[i]=j; return 0; } signed main(){ int n,m; cin>>n>>m; if(n==1){ cout<<"YES\n1\n1"; return 0; } for(int i=1;i<=n;i++)parent[i]=i; vector<int>v[n+1]; for(int i=0;i<m;i++){ int x,y; cin>>x>>y; v[x].pb(y); v[y].pb(x); if(unite(x,y)){ cout<<"NO\n"; return 0; } } int guy=0; for(int i=1;i<=n;i++){ if(v[i].size()>2){ guy=i; } } if(!guy){ for(int i=1;i<=n;i++){ if(v[i].size()==1){ guy=v[i][0]; break; } } } vector<int>chain; chain.pb(guy); while(1){ int past=-1; if(1<chain.size())past=chain[chain.size()-2]; int now=chain.back(); for(int j:v[now]){ if(j!=past&&v[j].size()>1){ if(chain.back()!=now){ cout<<"NO\n"; return 0; } chain.pb(j); } } if(chain.back()==now){ break; } } for(int i=1;i+1<chain.size();i++){ if(2<v[chain[i]].size()){ cout<<"NO\n"; return 0; } } cout<<"YES\n"; vector<int>ans; for(int i=0;i<chain.size();i++){ ans.pb(chain[i]); } for(int i=chain.size()-1;0<=i;i--){ ans.pb(chain[i]); } cout<<ans.size()<<'\n'; for(int i:ans)cout<<i<<' '; }
Compilation message
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 336 KB | Output is correct |
2 | Correct | 1 ms | 336 KB | Output is correct |
3 | Correct | 1 ms | 336 KB | Output is correct |
4 | Correct | 1 ms | 504 KB | Output is correct |
5 | Correct | 1 ms | 336 KB | Output is correct |
6 | Correct | 1 ms | 336 KB | Output is correct |
7 | Correct | 1 ms | 336 KB | Output is correct |
8 | Incorrect | 1 ms | 500 KB | Output isn't correct |
9 | Halted | 0 ms | 0 KB | - |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 1 ms | 336 KB | Output is correct |
2 | Correct | 1 ms | 336 KB | Output is correct |
3 | Correct | 1 ms | 336 KB | Output is correct |
4 | Correct | 1 ms | 336 KB | Output is correct |
5 | Correct | 1 ms | 336 KB | Output is correct |
6 | Correct | 1 ms | 336 KB | Output is correct |
7 | Correct | 1 ms | 504 KB | Output is correct |
8 | Correct | 1 ms | 336 KB | Output is correct |
9 | Correct | 1 ms | 336 KB | Output is correct |
10 | Correct | 1 ms | 336 KB | Output is correct |
11 | Correct | 1 ms | 336 KB | Output is correct |
12 | Correct | 1 ms | 336 KB | Output is correct |
13 | Correct | 1 ms | 336 KB | Output is correct |
14 | Correct | 1 ms | 336 KB | Output is correct |
15 | Correct | 1 ms | 508 KB | Output is correct |
16 | Correct | 1 ms | 336 KB | Output is correct |
17 | Correct | 1 ms | 336 KB | Output is correct |
18 | Correct | 2 ms | 504 KB | Output is correct |
19 | Correct | 2 ms | 336 KB | Output is correct |
20 | Correct | 1 ms | 508 KB | Output is correct |
# | 결과 | 실행 시간 | 메모리 | Grader output |
---|---|---|---|---|
1 | Correct | 2 ms | 336 KB | Output is correct |
2 | Correct | 1 ms | 336 KB | Output is correct |
3 | Correct | 1 ms | 336 KB | Output is correct |
4 | Correct | 1 ms | 504 KB | Output is correct |
5 | Correct | 1 ms | 336 KB | Output is correct |
6 | Correct | 1 ms | 336 KB | Output is correct |
7 | Correct | 1 ms | 336 KB | Output is correct |
8 | Incorrect | 1 ms | 500 KB | Output isn't correct |
9 | Halted | 0 ms | 0 KB | - |