【图论】拓扑排序

昨天复习的知识点。

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

相关推荐
故事和你916 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
故事和你9113 小时前
洛谷-数据结构1-4-图的基本应用2
开发语言·数据结构·算法·深度优先·动态规划·图论
玉树临风ives15 小时前
atcoder ABC 454 题解
算法·深度优先·图论
_小草鱼_18 小时前
【搜索与图论】BFS与DFS的区别
深度优先·图论·宽度优先
kronos.荒1 天前
图论——求孤岛面积、淹没孤岛(python)
python·深度优先·图论
故事和你912 天前
洛谷-数据结构-1-3-集合3
数据结构·c++·算法·leetcode·贪心算法·动态规划·图论
啊我不会诶2 天前
牛客练习赛151
算法·深度优先·图论
深念Y3 天前
图数据库 vs 向量数据库:AI时代的两个“最强大脑”
数据库·人工智能·neo4j·图论··向量·rag
君义_noip3 天前
信息学奥赛一本通 4163:【GESP2512七级】城市规划 | 洛谷 P14921 [GESP202512 七级] 城市规划
c++·算法·图论·gesp·信息学奥赛
会编程的土豆3 天前
【日常做题】 代码随想录(岛屿最大面积+寻宝)
数据结构·算法·图论