【图论】拓扑排序

昨天复习的知识点。

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

相关推荐
蒙奇D索大2 天前
【数据结构】图论最短路圣器:Floyd算法如何用双矩阵征服负权图?
数据结构·算法·矩阵·图论·图搜索算法
芜湖xin3 天前
【题解-洛谷】B4292 [蓝桥杯青少年组省赛 2022] 路线
算法·图论·bfs·图的遍历
LunaGeeking3 天前
重要的城市(图论 最短路)
c++·算法·编程·图论·最短路·floyd
闻缺陷则喜何志丹4 天前
【强连通分量 拓扑序】P9431 [NAPC-#1] Stage3 - Jump Refreshers|普及+
c++·算法·图论·拓扑序·洛谷·强连通分量
蒙奇D索大7 天前
【数据结构】图论最短路径算法深度解析:从BFS基础到全算法综述
数据结构·算法·图论·广度优先·图搜索算法
计信金边罗10 天前
是否存在路径(FIFOBB算法)
算法·蓝桥杯·图论
闻缺陷则喜何志丹12 天前
【二分图 图论】P9384 [THUPC 2023 决赛] 着色|普及+
c++·算法·图论·二分图·洛谷
鸽子炖汤12 天前
LRC and VIP
c++·算法·图论
JK0x0714 天前
代码随想录算法训练营 Day61 图论ⅩⅠ Floyd A※ 最短路径算法
算法·图论
qq_4474294114 天前
数据结构与算法:图论——拓扑排序
linux·c语言·学习·图论