#include<bits/stdc++.h>
#define int long long
const int N = 2e4+5;
using namespace std;
map<string,int>st;
vector<int>g[N];
void add(int u,int v){
g[u].push_back(v);
}
int n,m,cnt,tot,dfn[N],low[N],root;
stack<int>sp;
int IsCut[N];
int ans;
void tarjan(int u,int fa){
dfn[u] = low[u] = ++cnt;
int ch=0;
for(auto v:g[u]){
if(!dfn[v]){
ch++;
tarjan(v,u);
low[u] = min(low[u],low[v]);
if(low[v]>=dfn[u]&&u!=root){
IsCut[u] = 1;ans++;
}
}else{
if(v!=fa)
low[u] = min(dfn[v],low[u]);
}
}
if(u==root&&ch>=2){
IsCut[u] = 1;ans++;
}
}
signed main(){
cin>>n>>m;
for(int i=1;i<=m;i++){
int u,v;
cin>>u>>v;
add(u,v);
add(v,u);
}
for(int i=1;i<=n;i++){
if(!dfn[i])
root=i,tarjan(i,-1);
}
ans=0;
for(int i=1;i<=n;i++){
if(IsCut[i])
ans++;
}
cout<<ans<<"\n";
for(int i=1;i<=n;i++){
if(IsCut[i])
cout<<i<<" ";
}
return 0;
}