关键路径(C语言实现)

本文介绍了如何在有向无环图(AOE网)中寻找关键路径,关键路径是工程中最短完工时间的路径。文章通过C语言程序展示了如何计算各个事件的最早发生和最晚发生时间,并据此找出关键路径。通过对示例图1的分析,解释了关键路径的概念和其在工程管理中的意义。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

实际场景中,对于某项工程中的各个任务以及完成它们的先后次序,我们经常用有向无环网(带权的有向无环图)来表示。

图 1 有向无环图

图 1 就是一张有向无环网,整张网表示一项工程,顶点 V1~V9 表示工程中的各个任务;弧 a1~a11 表示执行各个任务的先后次序,各个弧的权值表示完成各个任务所需要的时间。

类似上面这样,当我们用有向无环网描述某项工程时,数据结构中称这样的网结构为 AOE(Activity On Edge)网,网中的顶点称为“事件”,弧称为“活动”,弧对应的权值代表活动持续的时间。

在 AOE 网中,每个事件表示在它之前的活动已经完成,之后的活动可以开始。例如图 1 中,V5 表示 a4 和 a5 已经完成,a7 和 a8 可以开始。

通常情况下,AOE 网中只有一个开始顶点和一个结束顶点,比如图 1 表示的整个工程从 V1 开始,一直到 V9 结束。开始顶点就是入度为 0 的顶点,又称“源点”;结束顶点就是出度为 0 的顶点,又称“汇点”。

搞清楚事件、活动、源点、汇点这些词汇的含义之后,接下来的讲解中将使用它们。

再次观察图 1,对 a1->a4->a7->a10 和 a1->a4->a8-

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值