拓扑排序

Posted lemon1234

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了拓扑排序相关的知识,希望对你有一定的参考价值。

拓扑排序:

head[u]: 以u为起点的边,最前面的边的编号

拓朴排序模板:邻接表(结构体+队列实现)

技术图片
#include<iostream>
#include<cstring>
#include<queue>
using namespace std;
const int maxn = 1e5+5;
int head[maxn],in[maxn],topo[maxn],n,m,num; 
struct Edge
    int u;
    int v;
    int next;
edge[maxn];
void addEdge(int u,int v)
    edge[num].u = u;
    edge[num].v = v;
    edge[num].next = head[u];
    head[u] = num++;
 
void init()
    memset(head,-1,sizeof(head));
    memset(in,0,sizeof(in));

int topoSort()

    queue<int>q;
    for(int i=1;i<=n;i++)
    
        if(in[i]==0)
            q.push(i);
        
    
    int t = 0;
    while(!q.empty())
    
        int u=q.front();
        q.pop();
        topo[t++]=u;
        for(int i=head[u]; i!=-1; i=edge[i].next)
            int v=edge[i].v;
            in[v]--;
            if(in[v]==0)
                q.push(v);
            
        
    

int main()

    init();
    cin>>n>>m;
    for(int i=0;i<m;i++)
        int u,v;
        cin>>u>>v;
        in[v]++;
        addEdge(u,v);
    
    topoSort();    
    for(int i=0;i<n;i++)
        cout<<topo[i]<<" ";
    
    return 0;

/*
7 7
1 7
2 3
2 4
3 4
3 5
6 5
7 6
topo:1 2 7 3 6 4 5 
*/
View Code 

以上是关于拓扑排序的主要内容,如果未能解决你的问题,请参考以下文章

拓扑排序

『拓扑排序』拓扑排序模板

拓扑排序算法实现

图 - 拓扑排序 (二)

拓扑排序

拓扑排序+关键路径