在算法课的时候老师讲过最小生成树,生成树的原理挺简单来着,可是要用代码实现它还是有一定难度╭(╯^╰)╮,本人学渣,没有逼迫没有学习,所以知道这个算法一直没有实现,直到前几天一道蓝桥杯历届试题拦住了我,这个题网上查了查要两次kruskal,然后翻出了算法书⊙0⊙,emmmm……算了我还是先把最小生成树两个方法先过一遍吧
最小生成树
性质:n个节点生成的最小生成树有n-1条边 & 最小生成树里多加一条边能生成含该边的一个环
构造方法:Prim算法 & Kruskal算法
一、Prim算法:逐个点连通的方式构造最小生成树(时间复杂度O(n*n),适合稠密图)
稀疏图&稠密图:有很少条边或弧(边的条数|E|远小于|V|²)的图称为稀疏图(sparse graph),反之边的条数|E|接近|V|²,称为稠密图(dense graph)。
Prim算法是从一个点开始,在给的无向图中寻找这个点所连接的权值最小的边,并在树中连接这条边,再寻找树中节点在无向图连接的权值最小的边,找到之后要判断这条边是否会构成一个环,最小生成树中是不能出现环的。
下图的例子:①从点1开始,权值最小的边是ÿ