拓扑排序模板

#include<iostream>
#include<algorithm>
#include<queue>
#include<cstring>
#define maxn 100006
using namespace std;
struct node
{
    int w;
    int to;
    int next;
}edge[maxn];
int cnt;
int s[maxn];
int head[maxn];
int n,m,seq[maxn];
int indeg[maxn];
int indegree[maxn];//算入度用的集合;
void add(int u,int v)//链式前向星存图;
{
    edge[cnt].to=v;
    edge[cnt].next=head[u];
    head[u]=cnt++;
}
int topu()
{
    queue<int>q;//维护入度为零的队列;
    for(int i=1;i<=n;i++)
    {
        indeg[i]=indegree[i];
        if(indeg[i]==0)
            q.push(i);
    }
    int k=0;
    bool res=false;
    while(!q.empty())
    {
        if(q.size()!=1)//每次入度为零的只能有一个,不然有其他路径;
            res=true;
        int u=q.front();
        q.pop();
        seq[k++]=u;//seq为排好的顺序;
        for(int i=head[u];i!=-1;i=edge[i].next)
        {
            int v=edge[i].to;
            indeg[v]--;
            if(indeg[v]==0)
            {
                q.push(v);
            }
        }
    }
    //cout<<"k="<<k<<endl;
    if(k<n)
        return -1;//存在有向环;
    if(res)
        return 0;//拓扑排序不只一条路径;
    return 1;//一种路径
}
int main()
{
    int x,y;
    while(cin>>n>>m)
    {
        memset(head,-1,sizeof(head));
        memset(indeg,0,sizeof(indeg));
        memset(indegree,0,sizeof(indegree));
        for(int i=1;i<=m;i++)
        {
            cin>>x>>y;
            add(x,y);
            indegree[y]++;
        }
        int z=topu();
           // for(int i=0;i<n;i++)
            //cout<<seq[i]<<endl;
        cout<<z<<endl;
    }
    return 0;
}

原文地址:https://www.cnblogs.com/huangdao/p/7706130.html