*图论基础(5)

持续更新...

1.图的基本概念

不写了,网上有好多资料ovo

2.图的存储和遍历

2.1存储:

3.最小生成树

3.2Kruskal算法

4.拓扑排序

拓扑排序的⽬标是将有向⽆环图中的所有结点排序,使得排在前⾯的结点不能依赖于排在后⾯的结
点。在课程问题中,相当于就是找到⼀个排课的合法顺序。具体流程可借助队列进⾏:

vbnet 复制代码
1. 将图中所有⼊度为 0 的点,加⼊到队列中;
2. 取出队头元素,删除与该点相连的边。如果删除之后的后继结点的⼊度变为 0,加⼊到队列中;
3. 重复 2 操作,直到图中没有点或者没有⼊度为 0 的点为⽌。

拓扑排序判断是否有环:
跑⼀遍拓扑排序算法,如果有结点没有进队,那么就表明有环。
【题⽬描述】
有个⼈的家族很⼤,辈分关系很混乱,请你帮整理⼀下这种关系。给出每个⼈的后代的信息。输出⼀个序列,使得每个⼈的后辈都⽐那个⼈后列出。
【输⼊描述】
第 1⾏⼀个整数N ,表⽰家族的⼈数。接下来 N⾏,第 i⾏描述第i 个⼈的后代编号ai,j ,表⽰ai,j 是i 的后代。每⾏最后是0 表⽰描述完毕。
【输出描述】
输出⼀个序列,使得每个⼈的后辈都⽐那个⼈后列出。如果有多种不同的序列,输出任意⼀种即可。

5.单源最短路

vbnet 复制代码
• 单源最短路,即图中⼀个顶点到其它各顶点的最短路径。
• 多源最短路,即图中每对顶点间的最短路径

5.2 bellman-ford 算法(很暴力)
是⼀种基于松弛操作的最短路算法,可以求出有负权的图的最短路,并可以对最短路不存在的情况进⾏判断。
算法核⼼思想:不断尝试对图上每⼀条边进⾏松弛,直到所有的点都⽆法松弛为⽌。

6.多元最短路

相关推荐
故事和你9114 小时前
洛谷-算法2-3-分治与倍增5
开发语言·数据结构·c++·算法·动态规划·图论
WolfGang00732117 小时前
代码随想录算法训练营 Day49 | 图论 part07
算法·图论
WolfGang0073212 天前
代码随想录算法训练营 Day48 | 图论 part06
算法·图论
WolfGang0073213 天前
代码随想录算法训练营 Day47 | 图论 part05
算法·图论
WolfGang0073214 天前
代码随想录算法训练营 Day46 | 图论 part04
算法·图论
故事和你914 天前
洛谷-算法2-2-常见优化技巧3
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
自我意识的多元宇宙5 天前
图---图的应用(最短路径)
图论
故事和你915 天前
洛谷-算法2-2-常见优化技巧1
开发语言·数据结构·c++·算法·动态规划·图论
WolfGang0073215 天前
代码随想录算法训练营 Day45 | 图论 part03
算法·图论
故事和你916 天前
洛谷-算法2-1-前缀和、差分与离散化2
开发语言·数据结构·算法·深度优先·动态规划·图论