【图论】拓扑排序

昨天复习的知识点。

​先复习一下 AOE网

AOE网,简单来说就是工程的带权有向图,其中:

  • 顶点:活动开始或者结束的事件
  • 边:活动
  • 边的权值:完成该活动所需的时间

在AOE网中,想要完成一项活动,必须要先完成在该活动前面的所有活动,例如下图中,想要完成活动e,必须要先完成活动abcd,完成活动a和c所需时间为3 + 2 = 5,完成活动b和d所需时间为5 + 4 = 9,二者取大,因此任务e的最早开始时间为9。

由此我们可以知道,整个工程从开始到结束所需要花费的时间是起始点到终止点的最大路径长度(因为这样才可以保证在终止点前的所有任务都完成了),这个有最大路径长度的路径就是关键路径,关键路径上的活动就叫做关键活动。

​总的来说,拓扑排序就是,后层的结点要依赖于前层的结点。

接下来分析一下拓扑排序和最短路的不同之处(主要是和dijkstra的不同之处),每次更新结点距离时,dijkstra是在当前结点距离大于更新后时才进行更新,同时只有被更新的结点才会入队,但是拓扑排序是在当前结点距离和被更新后距离中取最大的,同时将更新结点入度减一,且入队条件是当前结点入度为0。

模板代码:

cpp 复制代码
queue<int> q;
vector<int> et(n + 1);
for (int i = 1; i <= n; i ++ )
    if (ind[i] == 0)
    {
        et[i] = w[i];
        q.push(i);
    }
while (q.size())
{
    auto t = q.front();
    q.pop();
    for (int i = 0; i < g[t].size(); i ++ )
    {
        int j = g[t][i];
        et[j] = max(et[j], et[t] + w[j]);
        ind[j] -- ;
        if (ind[j] == 0) q.push(j);
    }
}

三道例题见24.1.25的训练记录

相关推荐
闪电麦坤951 天前
数据结构:图的表示 (Representation of Graphs)
数据结构·算法·图论
BlackPercy2 天前
【图论】Graphs.jl 最小生成树算法文档
算法·图论
SuperCandyXu3 天前
洛谷 P3128 [USACO15DEC] Max Flow P -普及+/提高
c++·算法·图论·洛谷
zc.ovo3 天前
牛子图论1(二分图+连通性)
数据结构·c++·算法·深度优先·图论
ltrbless3 天前
最小生成树算法详解
算法·排序算法·图论
love you joyfully4 天前
图论简介与图神经网络(Dijkstra算法,图卷积网络GCN实战)
人工智能·深度学习·神经网络·算法·贪心算法·图论
YA10JUN5 天前
数据结构基础--最小生成树
数据结构·算法·图论
啊我不会诶7 天前
【图论】最短路算法
算法·图论
xwztdas10 天前
AT_abc401_f [ABC401F] Add One Edge 3
图论·广度优先·树的直径
花开富贵ii11 天前
代码随想录算法训练营四十九天|图论part07
java·数据结构·算法·图论·prim·kruscal