码迷,mamicode.com
首页 > 编程语言 > 详细

拓扑排序模板

时间:2019-02-15 01:26:00      阅读:159      评论:0      收藏:0      [点我收藏+]

标签:pre   pop   push   read   int   邻接表   from   while   拓扑   

邻接表使用vector实现

void read()
{
    cin >> n >> m;
    for (int i = 1; i <= m; i++)
    {
        cin >> x >> y;
        edge[x].push_back(y);
        in[y]++;
    }
}
void topo_sort()
{
    for (int i = 1; i <= n;i++)
        if (!in[i]) que.push(i);
    while (!que.empty())
    {
        int v = que.front();
        que.pop();
        ans.push_back(v);
        for (int i = 0; i < edge[v].size(); i++)
        {
            if (--in[edge[v][i]] == 0) 
                que.push(edge[v][i]);
        }
    }
}

使用数组实现邻接表

void add_edge(int from, int to)
{
    ver[++tot] = to;
    Next[tot] = head[from];
    head[from] = tot;
    in[to]++;
}

 

拓扑排序模板

标签:pre   pop   push   read   int   邻接表   from   while   拓扑   

原文地址:https://www.cnblogs.com/xiaoguapi/p/10381363.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!