【图论】拓扑排序

昨天复习的知识点。

​先复习一下 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的训练记录

相关推荐
C蔡博士11 小时前
最小生成树(MST)详解:定义、算法与核心性质
算法·贪心算法·图论·时间复杂度
jing-ya1 天前
day 57 图论part9
java·开发语言·数据结构·算法·图论
_小草鱼_1 天前
【搜索与图论】BFS(广度优先搜索)
算法·图论·bfs·宽度优先
无敌憨憨大王1 天前
并查集(图论)
数据结构·算法·图论
_小草鱼_2 天前
【搜索与图论】DFS算法(深度优先搜索)
算法·深度优先·图论·回溯·递归
美好的事情能不能发生在我身上2 天前
Hot100中的:图论专题
图论
不染尘.2 天前
最小生成树算法
开发语言·数据结构·c++·算法·图论
I_LPL2 天前
day58 代码随想录算法训练营 图论专题11
数据结构·算法·图论
重生之后端学习3 天前
287. 寻找重复数
数据结构·算法·leetcode·深度优先·图论
I_LPL3 天前
day57 代码随想录算法训练营 图论专题10
图论