1. 问题[描述算法问题,首选形式化方式(数学语言),其次才是非形式化方式(日常语言)]
    在一给定的无向图G = (V, E) 中,(u, v) 代表连接顶点 u 与顶点 v 的边(即),而 w(u, v) 代表此边的权重,若存在 T 为 E 的子集(即)且为无向循环图,使得的 sum(w(u, v))最小,则此 T 为 G 的最小生成树。
  2. 解析[问题的理解和推导,可用电子版直接在此编写,也可用纸笔推导,拍照嵌入本文档]
    过程分析:首先任选一点a作为起始点,加入集合V,再从集合U-V中找到另一点b使得b到V中任意一点的权值最小,把b加入集合V。以此类推,现在集合V={a,b},再从集合U-V找到一点c使得c到V中任意一点的权值最小,将c加入集合V,此时就构建出一棵最小生成树。
  3. 设计[核心伪代码]
    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);}
  4. 分析[算法复杂度推导]顶点数v,边数e
    邻接矩阵:O(v) 邻接表:O(elog2v)
  5. 源码[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算法构建最小生成树相关推荐

  1. C语言实现Prim算法 —构建最小生成树

    目录 介绍Prim算法前的相关概念 一.Prim算法的思想 二.1.利用图形详细解释Prim算法的思想 Prim算法思想介绍 ​ 二.2利用图形又又解释Prim算法的思想 三.用图示结合代码中重要量进 ...

  2. 三十七、Prim算法--求解最小生成树

    一.Prim算法介绍 普利姆(Prim)算法求最小生成树,也就是在包含 n 个顶点的连通图中,找出只有(n-1)条边包含所有 n 个顶点的 连通子图,也就是所谓的极小连通子图 普利姆的算法如下: 设 ...

  3. prim算法 求最小生成树

    最小生成树Prim算法理解 标签: Prim算法理解最小生成树Prim 2014-08-16 18:49 18482人阅读 评论(5) 收藏 举报 版权声明:本文为博主原创文章,未经博主允许不得转载. ...

  4. 小黑算法成长日记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] ...

  5. Prim算法实现最小生成树

    Prim算法实现最小生成树 1.最小生成树是什么 2.最小生成树的用途 3.Prim算法描述 4.Prim算法演示最小生成树过程 5.Prim算法实现 END 1.最小生成树是什么 对连通图进行遍历, ...

  6. 1分钟解决Prim算法构造最小生成树

    数据结构期末上分必备 前言:Prim 算法构造最小生成树!!!跟着画一遍就会了!!! Kruskal 请移步 kruskal 题目 设有如下图所示的无向连通图,从顶点A出发,使用 Prim 算法构造最 ...

  7. prim算法_最小生成树的本质是什么?Prim算法道破天机

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法和数据结构专题20篇文章,我们继续最小生成树算法,来把它说完. 在上一篇文章当中,我们主要学习了最小生成树的Kruskal算法.今 ...

  8. Prim算法解决最小生成树 (解决修路问题)

    一.什么是Prim算法  普里姆算法查找最小生成树的过程,采用了贪心算法的思想.对于包含 N 个顶点的连通网,普里姆算法每次从连通网中找出一个权值最小的边,这样的操作重复 N-1 次,由 N-1 条权 ...

  9. Prim算法(最小生成树;例题:nyoj38)

    Prim:求最小生成树的另一个算法 还可以用Kruskal(https://blog.csdn.net/Radium_1209/article/details/80503384) 与Kruskal的不 ...

最新文章

  1. 非常好用的模糊pid温度控制算法_反应罐高低温温度控制装置
  2. 输入整型数组和排序标识,对其元素按照升序或降序进行排序(华为OJ系列)
  3. Spring mvc整合freemarker详解
  4. 用twisted为未来安排任务(Scheduling tasks for the future
  5. 如何通过css控制内容显示顺序 第二行的内容优先显示
  6. 信息学奥赛一本通(1409:判决素数个数)
  7. Sublime与远程服务器代码同步工具SFTP
  8. php include不可用,无法设置PHP include_path
  9. Linux无root权限安装cuda9.1和cudnn7.05以及编译框架时无lcuda.so的问题
  10. Bailian3256 矩阵的乘法【数学计算】
  11. SpringBoot学习之文件结构和配置文件
  12. (转载)C#中如何获取当前路径的几种方法
  13. 适用于Windows的Xcode:在PC上安装Xcode的5种方法
  14. 浅谈PMSM电机控制之Clark变换(详细推导及MATLAB仿真)
  15. Love Letter
  16. 数字中国建设峰会闭幕,现场海量图片一览!
  17. linux生成xorg,生成xorg.conf文件
  18. 3D视觉学习计划之PCL库的基础知识
  19. (算法练习)——小白鼠排队
  20. Time For Kids 很不错的英语学习周刊

热门文章

  1. 独立云计算服务商的多维实践之道:用户需求驱动变革
  2. 使用IntelliJ IDEA 15和Maven创建Java Web项目
  3. 谈谈 Docker 网络
  4. Webpack 资源管理
  5. JavaScript 各种遍历方式详解
  6. 块代码编程---开始使用块代码
  7. jQueryUI Repeater 无刷新删除 新建 更新数据 - JQueryElement [7]
  8. 用sql语句实现按时间求累计值
  9. ZooKeeper内部原理
  10. 共享思维导图,协作型思维导图Leangoo