拓扑排序

拓扑排序就是先让所以有入度为零的点入队列,然后将与入度为零的点相邻的点入度减一,如果减一后入度变为零就将该点加入对列
#include<iostream>
#include<vector>
#include<queue>
using namespace std;
const int N=2*1e5+5;
vector<int>v[N];
int inc[N];
int ans[N];
int n,m;
int cnt=0;
void tuopu(){
queue<int>q;
for(int i=1;i<=n;i++)if(!inc[i])q.push(i);
while(!q.empty()){
int x=q.front();
q.pop();
ans[++cnt]=x;
for(int i=0;i<v[x].size();i++){
inc[v[x][i]]--;
if(!inc[v[x][i]])q.push(v[x][i]);
}
}
}
int main(){
cin>>n>>m;
while(m--){
int x,y;
cin>>x>>y;
v[x].push_back(y);
inc[y]++;
}
tuopu();
if(cnt==n){
for(int i=1;i<=n;i++){
if(i!=n)cout<<ans[i]<<" ";
else cout<<ans[i];
}
}
else cout<<-1;
return 0;
}

浙公网安备 33010602011771号