拓扑排序


拓扑排序就是先让所以有入度为零的点入队列,然后将与入度为零的点相邻的点入度减一,如果减一后入度变为零就将该点加入对列

#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;
}
posted @ 2025-03-02 16:54  郭轩均  阅读(15)  评论(0)    收藏  举报