0pts求条
查看原帖
0pts求条
1320239
CSZ7943楼主2025/1/19 11:14

样例过了,还TLE两个点

#include<iostream>
#include<stack>
using namespace std;
int n,m;
struct node{
	int v,nxt;
}g[100005];
int en[5005];
int head[5005],num;
int vis[5005];
int sum;
bool f;
stack<int> q;
void add(int u,int v){
	g[++num].v=v;
	g[num].nxt=head[u];
	head[u]=num;
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=m;i++){
		int u,v;
		cin>>u>>v;
		add(u,v);
		en[v]++;
	}
	for(int i=1;i<=n;i++){
		if(en[i]==0){
			vis[i]=1;
			q.push(i);
		}
	}
	while(!q.empty()){
		int x=q.top();
		q.pop();
		cout<<x<<"\n";
		for(int i=head[x];i;i=g[i].nxt){
			en[g[i].v]--;
			if(en[i]==0){
				q.push(g[i].v);
				sum++;
			}
		}
		if(sum>1){
			f=1;
		}
	}
	cout<<f;
	return 0;
}
2025/1/19 11:14
加载中...