• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号
您的位置:首页 > 程序设计 >C语言 > 使用C语言实现最小生成树求解的简单方法

使用C语言实现最小生成树求解的简单方法

作者:姜南 字体:[增加 减小] 来源:互联网 时间:2017-05-28

姜南 通过本文主要向大家介绍了最小生成树c语言,最小生成树c,最小生成树prim算法c,最小生成树c 代码,最小生成树c语言代码等相关知识,希望对您有所帮助,也希望大家支持linkedu.com www.linkedu.com

最小生成树Prim算法朴素版
有几点需要说明一下。

1、2个for循环都是从2开始的,因为一般我们默认开始就把第一个节点加入生成树,因此之后不需要再次寻找它。

2、lowcost[i]记录的是以节点i为终点的最小边权值。初始化时因为默认把第一个节点加入生成树,因此lowcost[i] = graph[1][i],即最小边权值就是各节点到1号节点的边权值。

3、mst[i]记录的是lowcost[i]对应的起点,这样有起点,有终点,即可唯一确定一条边了。初始化时mst[i] = 1,即每条边都是从1号节点出发。

编写程序:对于如下一个带权无向图,给出节点个数以及所有边权值,用Prim算法求最小生成树。

2015819151522690.png (600×445)

输入数据:

7 11
A B 7
A D 5
B C 8
B D 9
B E 7
C E 5
D E 15
D F 6
E F 8
E G 9
F G 11

输出:

A - D : 5
D - F : 6
A - B : 7
B - E : 7
E - C : 5
E - G : 9
Total:39

最小生成树Prim算法朴素版 C语言实现 代码如下

#include <stdio.h>
#include <stdlib.h>
 
#define MAX 100
#define MAXCOST 0x7fffffff
 
int graph[MAX][MAX];
 
int Prim(int graph[][MAX], int n)
{
 /* lowcost[i]记录以i为终点的边的最小权值,当lowcost[i]=0时表示终点i加入生成树 */
 int lowcost[MAX];
 
 /* mst[i]记录对应lowcost[i]的起点,当mst[i]=0时表示起点i加入生成树 */
 int mst[MAX];
 
 int i, j, min, minid, sum = 0;
 
 /* 默认选择1号节点加入生成树,从2号节点开始初始化 */
 for (i = 2; i <= n; i++)
 {
 /* 最短距离初始化为其他节点到1号节点的距离 */
 lowcost[i] = graph[1][i];
 
 /* 标记所有节点的起点皆为默认的1号节点 */
 mst[i] = 1;
 }
 
 /* 标记1号节点加入生成树 */
 mst[1] = 0;
 
 /* n个节点至少需要n-1条边构成最小生成树 */
 for (i = 2; i <= n; i++)
 {
 min = MAXCOST;
 minid = 0;
 
 /* 找满足条件的最小权值边的节点minid */
 for (j = 2; j <= n; j++)
 {
  /* 边权值较小且不在生成树中 */
  if (lowcost[j] < min && lowcost[j] != 0)
  {
  min = lowcost[j];
  minid = j;
  }
 }
 /* 输出生成树边的信息:起点,终点,权值 */
 printf("%c - %c : %d\n", mst[minid] + 'A' - 1, minid + 'A' - 1, min);
 
 /* 累加权值 */
 sum += min;
 
 /* 标记节点minid加入生成树 */
 lowcost[minid] = 0;
 
 /* 更新当前节点minid到其他节点的权值 */
 for (j = 2; j <= n; j++)
 {
  /* 发现更小的权值 */
  if (graph[minid][j] < lowcost[j])
  {
  /* 更新权值信息 */
  lowcost[j] = graph[minid][j];
 
  /* 更新最小权值边的起点 */
  mst[j] = minid;
  }
 }
 }
 /* 返回最小权值和 */
 return sum;
}
 
int main()
{
 int i, j, k, m, n;
 int x, y, cost;
 char chx, chy;
 
 /* 读取节点和边的数目 */
 scanf("%d%d", &m, &n);
 getchar();
 
 /* 初始化图,所有节点间距离为无穷大 */
 for (i = 1; i <= m; i++)
 {
 for (j = 1; j <= m; j++)
 {
  graph[i][j] = MAXCOST;
 }
 }
 
 /* 读取边信息 */
 for (k = 0; k < n; k++)
 {
 scanf("%c %c %d", &chx, &chy, &cost);
 getchar();
 i = chx - 'A' + 1;
 j = chy - 'A' + 1;
 graph[i][j] = cost;
 graph[j][i] = cost;
 }
 
 /* 求解最小生成树 */
 cost = Prim(graph, m);
 
 /* 输出最小权值和 */
 printf("Total:%d\n", cost);
 
 //system("pause");
 return 0; 
}

</div>

Kruskal算法:

void Kruskal(Edge E[],int n,int e)
{
 int i,j,m1,m2,sn1,sn2,k;
 int vset[MAXE];
 for (i=0;i<n;i++) vset[i]=i; //初始化辅助数组
 k=1;          //k表示当前构造最小生成树的第几条边,初值为1
 j=0;          //E中边的下标,初值为0
 while (k<n)      //生成的边数小于n时循环
 { 
  m1=E[j].u;m2=E[j].v;    //取一条边的头尾顶点
 sn1=vset[m1];sn2=vset[m2]; //分别得到两个顶点所属的集合编号
 if (sn1!=sn2)    //两顶点属于不同的集合,该边是最小生成树的一条边
 { 
  printf(" (%d,%d):%d/n",m1,m2,E[j].w);
  k++;          //生成边数增1
  for (i=0;i<n;i++)    //两个集合统一编号
   if (vset[i]==sn2)  //集合编号为sn2的改为sn1
       vset[i]=sn1;
 }
 j++;     //扫描下一条边
 }
}

</div>

</div>
分享到:QQ空间新浪微博腾讯微博微信百度贴吧QQ好友复制网址打印

您可能想查找下面的文章:

  • 使用C语言实现最小生成树求解的简单方法

相关文章

  • 2017-05-28常用Hash算法(C语言的简单实现)
  • 2017-05-28利用ace的ACE_Task等类实现线程池的方法详解
  • 2017-05-28C++中求余运算符(%)示例详解
  • 2017-05-28C++获取本机MAC,IP,MASK地址的方法
  • 2017-05-28c++ 端口扫描程序实现案例
  • 2017-05-28Qt实现图片移动实例(图文教程)
  • 2017-05-28C++标准模板库函数sort的那些事儿
  • 2017-05-28C++多态的实现及原理详细解析
  • 2017-05-28详细对比C语言中的chmod()函数和fchmod()函数
  • 2017-05-28C语言WinSock学习笔记第1/2页

文章分类

  • JavaScript
  • ASP.NET
  • PHP
  • 正则表达式
  • AJAX
  • JSP
  • ASP
  • Flex
  • XML
  • 编程技巧
  • Android
  • swift
  • C#教程
  • vb
  • vb.net
  • C语言
  • Java
  • Delphi
  • 易语言
  • vc/mfc
  • 嵌入式开发
  • 游戏开发
  • ios
  • 编程问答
  • 汇编语言
  • 微信小程序
  • 数据结构
  • OpenGL
  • 架构设计
  • qt
  • 微信公众号

最近更新的内容

    • c#中实现退出程序后自动重新启动程序的方法
    • 用C实现PHP扩展 Fetch_Url 类数据抓取的方法
    • 怎么用C++提取任意一张图片的特征(从内存读取数据)
    • c语言中指针大小以及使用初始化问题
    • 浅谈c++中的stl中的map用法详解
    • C++继承中的访问控制实例分析
    • 详解C++中const_cast与reinterpret_cast运算符的用法
    • C++动态规划之背包问题解决方法
    • C++ 中指针和引用有什么区别详解
    • 基于C++ map中key使用指针问题的详解

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有