#include #include #include #include #include #include #include #include #include #include #define mkp make_pair #define mkt make_tuple #define rep(i,n) for(int i = 0; i < (n); ++i) #define all(v) v.begin(),v.end() using namespace std; typedef long long ll; const ll MOD=1e9+7; template void chmin(T &a,const T &b){if(a>b) a=b;} template void chmax(T &a,const T &b){if(a> g; vector ord,low,vis; vector articulations; vector bridges; LowLink(int N,vector> &g):N(N),g(g),ord(N),low(N),vis(N){} void dfs(int now,int par,int &cnt){ ord[now]=cnt++; vis[now]=1; bool isArt=false; int num=0; low[now]=ord[now]; for(auto e:g[now]){ if(e.to==par) continue; if(vis[e.to]){ chmin(low[now],ord[e.to]); }else{ num++; dfs(e.to,now,cnt); chmin(low[now],low[e.to]); if(ord[now]1) articulations.push_back(now); if(par!=-1&&isArt) articulations.push_back(now); } void build(){ int cnt=0; for(int i=0;i>N; vector> g(N); rep(i,N){ int a,b; cin>>a>>b; a--;b--; g[a].emplace_back(Edge{a,b,1,i}); g[b].emplace_back(Edge{b,a,1,i}); } LowLink LL(N,g); LL.build(); vector bridges=LL.bridges; vector used(N,0); for(auto e:bridges) used[e.id]=1; vector ans; rep(i,N) if(used[i]==0) ans.push_back(i); cout<