12分求助
查看原帖
12分求助
285617
黑影洞人楼主2021/10/5 13:18
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<vector>
#define N 10005
using namespace std;
int n,m,a,b,head[N],to[N],nxt[N],tot;
int rh[N],rt[N],rn[N],cmp[N],f,mmp,ans;
bool vis[N]; 
vector<int > out;
void add(int u,int v){
	to[++tot]=v;rt[tot]=u;
	nxt[tot]=head[u];rn[tot]=rh[v];
	head[u]=tot;rh[v]=tot;
}
void dfs(int x){
	vis[x]=1;
	for(int i=head[x];i;i=nxt[i]){
		if(!vis[to[i]])dfs(to[i]);
	}
	out.push_back(x);
}
void rd(int x,int f){
	vis[x]=1;cmp[x]=f;
	for(int i=rh[x];i;i=rn[i]){
		if(!vis[x])rd(rt[i],f);
	}
}
void kosaraju(){
	out.clear();
	memset(vis,0,sizeof(vis));
	for(int i=1;i<=n;i++){
		if(!vis[i])dfs(i);
	}
	memset(vis,0,sizeof(vis));
	for(int i=out.size()-1;i>=0;i--){
		if(!vis[out[i]])rd(i,f++);
	}
	f--;
}
void dfs2(int x){
	vis[x]=1;
	for(int i=rh[x];i;i=rn[i]){
		if(!vis[x])dfs2(rt[i]);
	}
}
signed main(){
	scanf("%d%d",&n,&m);
	for(int i=1;i<=m;i++){
		scanf("%d%d",&a,&b);
		add(a,b);
	}
	kosaraju();
	for(int i=1;i<=n;i++)if(cmp[i]==f)mmp=i,ans++;
	memset(vis,0,sizeof(vis));
	dfs2(mmp);
	for(int i=1;i<=n;i++){
		if(!vis[i]){
			printf("0");return 0;
		}
	}
	printf("%d",ans);
	return 0;
}



2021/10/5 13:18
加载中...