#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;
}