prim算法构建最小生成树
- 问题[描述算法问题,首选形式化方式(数学语言),其次才是非形式化方式(日常语言)]
在一给定的无向图G = (V, E) 中,(u, v) 代表连接顶点 u 与顶点 v 的边(即),而 w(u, v) 代表此边的权重,若存在 T 为 E 的子集(即)且为无向循环图,使得的 sum(w(u, v))最小,则此 T 为 G 的最小生成树。 - 解析[问题的理解和推导,可用电子版直接在此编写,也可用纸笔推导,拍照嵌入本文档]
过程分析:首先任选一点a作为起始点,加入集合V,再从集合U-V中找到另一点b使得b到V中任意一点的权值最小,把b加入集合V。以此类推,现在集合V={a,b},再从集合U-V找到一点c使得c到V中任意一点的权值最小,将c加入集合V,此时就构建出一棵最小生成树。 - 设计[核心伪代码]
for (i = 2; i <= n; i++) { min = MAXCOST; minid = 0; for (j = 2; j <= n; j++) { if (lowcost[j] < min && lowcost[j] != 0) { min = lowcost[j];//找出权值最短的路径长度 minid = j; //找出最小的ID } } printf(“V%d-V%d=%d\n”,mst[minid],minid,min); sum += min;//求和 lowcost[minid] = 0;//该处最短路径置为0 for (j = 2; j <= n; j++) { if (graph[minid][j] < lowcost[j])//对这一点直达的顶点进行路径更新 { lowcost[j] = graph[minid][j]; mst[j] = minid; } } } printf(“最小权值之和=%d\n”,sum);} - 分析[算法复杂度推导]顶点数v,边数e
邻接矩阵:O(v) 邻接表:O(elog2v) - 源码[github源码地址]
#include<stdio.h> #define MAX 100 #define MAXCOST 0x7fffffff int graph[MAX][MAX]; void prim(int graph[][MAX], int n) { int lowcost[MAX]; int mst[MAX]; int i, j, min, minid, sum = 0; for (i = 2; i <= n; i++) { lowcost[i] = graph[1][i];//lowcost存放顶点1可达点的路径长度 mst[i] = 1;//初始化以1位起始点 } mst[1] = 0; for (i = 2; i <= n; i++) { min = MAXCOST; minid = 0; for (j = 2; j <= n; j++) { if (lowcost[j] < min && lowcost[j] != 0) { min = lowcost[j];//找出权值最短的路径长度 minid = j; //找出最小的ID } } printf(“V%d-V%d=%d\n”,mst[minid],minid,min); sum += min;//求和 lowcost[minid] = 0;//该处最短路径置为0 for (j = 2; j <= n; j++) { if (graph[minid][j] < lowcost[j])//对这一点直达的顶点进行路径更新 { lowcost[j] = graph[minid][j]; mst[j] = minid; } } } printf(“最小权值之和=%d\n”,sum);} int main() { int i, j, k, m, n; int x, y, cost; //freopen(“1.txt”,“r”,stdin);//文件输入 scanf("%d%d",&m,&n);//m=顶点的个数,n=边的个数 for (i = 1; i <= m; i++)//初始化图 { for (j = 1; j <= m; j++) { graph[i][j] = MAXCOST; } } for (k = 1; k <= n; k++) { scanf("%d%d%d",&i,&j,&cost); graph[i][j] = cost; graph[j][i] = cost; } prim(graph, m); return 0; }
prim算法构建最小生成树相关推荐
- C语言实现Prim算法 —构建最小生成树
目录 介绍Prim算法前的相关概念 一.Prim算法的思想 二.1.利用图形详细解释Prim算法的思想 Prim算法思想介绍 二.2利用图形又又解释Prim算法的思想 三.用图示结合代码中重要量进 ...
- 三十七、Prim算法--求解最小生成树
一.Prim算法介绍 普利姆(Prim)算法求最小生成树,也就是在包含 n 个顶点的连通图中,找出只有(n-1)条边包含所有 n 个顶点的 连通子图,也就是所谓的极小连通子图 普利姆的算法如下: 设 ...
- prim算法 求最小生成树
最小生成树Prim算法理解 标签: Prim算法理解最小生成树Prim 2014-08-16 18:49 18482人阅读 评论(5) 收藏 举报 版权声明:本文为博主原创文章,未经博主允许不得转载. ...
- 小黑算法成长日记18:基于Prim算法的最小生成树
import math nodes = ['A','B','C','D','E','F'] # 结点数组 vecs = [[0,1,6],[0,2,1],[0,3,5],[1,0,6],[1,2,5] ...
- Prim算法实现最小生成树
Prim算法实现最小生成树 1.最小生成树是什么 2.最小生成树的用途 3.Prim算法描述 4.Prim算法演示最小生成树过程 5.Prim算法实现 END 1.最小生成树是什么 对连通图进行遍历, ...
- 1分钟解决Prim算法构造最小生成树
数据结构期末上分必备 前言:Prim 算法构造最小生成树!!!跟着画一遍就会了!!! Kruskal 请移步 kruskal 题目 设有如下图所示的无向连通图,从顶点A出发,使用 Prim 算法构造最 ...
- prim算法_最小生成树的本质是什么?Prim算法道破天机
本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法和数据结构专题20篇文章,我们继续最小生成树算法,来把它说完. 在上一篇文章当中,我们主要学习了最小生成树的Kruskal算法.今 ...
- Prim算法解决最小生成树 (解决修路问题)
一.什么是Prim算法 普里姆算法查找最小生成树的过程,采用了贪心算法的思想.对于包含 N 个顶点的连通网,普里姆算法每次从连通网中找出一个权值最小的边,这样的操作重复 N-1 次,由 N-1 条权 ...
- Prim算法(最小生成树;例题:nyoj38)
Prim:求最小生成树的另一个算法 还可以用Kruskal(https://blog.csdn.net/Radium_1209/article/details/80503384) 与Kruskal的不 ...
最新文章
- 非常好用的模糊pid温度控制算法_反应罐高低温温度控制装置
- 输入整型数组和排序标识,对其元素按照升序或降序进行排序(华为OJ系列)
- Spring mvc整合freemarker详解
- 用twisted为未来安排任务(Scheduling tasks for the future
- 如何通过css控制内容显示顺序 第二行的内容优先显示
- 信息学奥赛一本通(1409:判决素数个数)
- Sublime与远程服务器代码同步工具SFTP
- php include不可用,无法设置PHP include_path
- Linux无root权限安装cuda9.1和cudnn7.05以及编译框架时无lcuda.so的问题
- Bailian3256 矩阵的乘法【数学计算】
- SpringBoot学习之文件结构和配置文件
- (转载)C#中如何获取当前路径的几种方法
- 适用于Windows的Xcode:在PC上安装Xcode的5种方法
- 浅谈PMSM电机控制之Clark变换(详细推导及MATLAB仿真)
- Love Letter
- 数字中国建设峰会闭幕,现场海量图片一览!
- linux生成xorg,生成xorg.conf文件
- 3D视觉学习计划之PCL库的基础知识
- (算法练习)——小白鼠排队
- Time For Kids 很不错的英语学习周刊