记录编号 206174 评测结果 AAAAAAAAAA
题目名称 备用交换机 最终得分 100
用户昵称 Gravatar一個人的雨 是否通过 通过
代码语言 C++ 运行时间 0.005 s
提交时间 2015-11-06 09:30:57 内存使用 9.73 MiB
显示代码纯文本
#include<map>
#include<set>
#include<queue>
#include<cmath>
#include<ctime>
#include<stack>
#include<cstdio>
#include<vector>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define LL long long
using namespace std;
const int maxn=1110;
int n,tot=0,h[maxn];
struct edge{
	int to,next;
}G[maxn*maxn];
int low[maxn],dfn[maxn],ind=0;
bool flag[maxn];

void add(int x,int y){
	++tot; G[tot].to=y;
	G[tot].next=h[x]; h[x]=tot;
}

void tarjan(int x,int fa){
	low[x]=dfn[x]=++ind;
	int k=0;
	for (int i=h[x];i;i=G[i].next){
		int v=G[i].to;
		if (!dfn[v]){
			k++; tarjan(v,x);
			low[x]=min(low[v],low[x]);
			if (low[v]>=dfn[x]) flag[x]=1;
		}else if (dfn[v]<dfn[x]&&v!=fa)
			low[x]=min(low[x],dfn[v]);
	}
	if (fa<0&&k==1) flag[x]=0;
}

int main(){
	freopen("gd.in","r",stdin);
	freopen("gd.out","w",stdout);
	scanf("%d",&n); int x,y;
	while (scanf("%d%d",&x,&y)==2){
		add(x,y); add(y,x);
	}
	for (int i=1;i<=n;++i)
		if (!dfn[i])
		   tarjan(i,-1);
	int ans=0;
	for (int i=1;i<=n;++i)
		if (flag[i]) ans++;
	printf("%d\n",ans);
	for (int i=1;i<=n;++i)
		if (flag[i]) printf("%d\n",i);
	return 0;
}