最小生成树Prim算法
文章作者:甘航 文章来源:http://www.cnblogs.com/ganhang-acm/转载请注明,谢谢合作。
由于数据结构老师布置的一道题 ,我看prim算法看了半天还是一知半解。
在浏览过n多大神博客后半copy半自动补脑完成了这道渣渣题。、、
题目就是从老师给的两个文件中读取数据求最小生成树。
第一个城市文件
北京 , 上海 , 天津 , 石家庄 , 太原 , 呼和浩特 , 沈阳 , 长春 ,哈尔滨 ,
济南 , 南京 , 合肥 , 杭州 , 南昌 , 福州 , 台北 , 郑州 , 武汉 ,
长沙 , 广州 , 海口 , 南宁 , 西安 , 银川 , 兰州 , 西宁 ,
乌鲁木齐 , 成都 , 贵阳 , 昆明 , 拉萨 , * -,
city.txt
第二个各城市之间距离文件
distance.txt
要求是根据这两个文件数据 求个城市最小生成树;
下面给出具体代码
代码的注释我写得很详细,方便理解,有几点需要说明一下。
1、2个for循环都是从1开始的,因为一般我们默认开始就把第0个节点加入生成树,因此之后不需要再次寻找它。
2、lowcost[i]记录的是以节点i为终点的最小边权值。初始化时因为默认把第0个节点加入生成树,因此lowcost[i] = graph[0][i],即最小边权值就是各节点到0号节点的边权值。
3、mst[i]记录的是lowcost[i]对应的起点,这样有起点,有终点,即可唯一确定一条边了。初始化时mst[i] = 0,即每条边都是从0号节点出发。
#include <stdio.h>
#include <string.h>
#include <stdlib.h>
#define inf 1<<30
#define node_num 31// 图的节点数
struct node
{
char s[];//存城市名字
int id;//这个可以不要,可以用c的下标表示
} c[node_num];
int G[node_num][node_num];//图的矩阵表示
int Prim()
{
int lowcost[node_num];/* lowcost[i]记录以i为终点的边的最小权值,当lowcost[i]=0时表示终点i加入生成树 */
int mst[node_num];/* mst[i]记录对应lowcost[i]的起点,当mst[i]=0时表示起点i加入生成树 */
int i,j,min,minid,sum=; for(i=; i<node_num; i++)/* 默认选择0号节点加入生成树,从1号节点开始初始化 */
{
lowcost[i]=G[][i];/* 最短距离初始化为其他节点到0号节点的距离 */
mst[i]=;/* 标记所有节点的起点皆为默认的0号节点 */
}
mst[]=;/* 标记0号节点加入生成树 */
for(i=; i<node_num; i++)/* n个节点至少需要n-1条边构成最小生成树 */
{
min=inf;
minid=;
for(j=; j<node_num; j++)/* 找满足条件的最小权值边的节点minid */
{
if(lowcost[j]<min&&lowcost[j]!=)/* 边权值较小且不在生成树中 */
{
min=lowcost[j];
minid=j;
}
}
printf("%s -- %s: %d\n",c[mst[minid]].s,c[minid].s,min);/* 输出生成树边的信息:起点,终点,权值 */ sum+=min;/* 累加权值 */ lowcost[minid]=;/* 标记节点minid加入生成树 */
for(j=; j<node_num; j++)/* 更新当前节点minid到其他节点的权值 */
{
if(G[minid][j]<lowcost[j])/* 发现更小的权值 */
{
lowcost[j]=G[minid][j];/* 更新权值信息 */
mst[j]=minid;/* 更新最小权值边的起点 */
}
}
}
return sum;/* 返回最小权值和 */
}
int main()
{
int i,j,w;
for(i=; i<node_num; i++)
for(j=; j<node_num; j++)
{
G[i][j]=G[j][i]=inf;/* 初始化图,所有节点间距离为无穷大 */
}
//读取城市信息
freopen("city.txt","r",stdin);
for(i=; i<node_num; i++)
{
scanf("%s",c[i].s);
scanf("%d,",&c[i].id);
}
//读取各城市之间的距离(权值)
freopen("distance.txt","r",stdin);
for(i=; i<node_num; i++)
for(j=; j<=i; j++)
{
scanf("%d",&w);
if(w!=)
G[i][j]=G[j][i]=w;
} int sum=Prim();//求最小生成树
printf("总长度:%d",sum);//输出最小权值和
return ;
}
Prim_v1.1
最小生成树Prim算法的更多相关文章
- 数据结构代码整理(线性表,栈,队列,串,二叉树,图的建立和遍历stl,最小生成树prim算法)。。持续更新中。。。
//归并排序递归方法实现 #include <iostream> #include <cstdio> using namespace std; #define maxn 100 ...
- 最小生成树Prim算法(邻接矩阵和邻接表)
最小生成树,普利姆算法. 简述算法: 先初始化一棵只有一个顶点的树,以这一顶点开始,找到它的最小权值,将这条边上的令一个顶点添加到树中 再从这棵树中的所有顶点中找到一个最小权值(而且权值的另一顶点不属 ...
- 最小生成树—prim算法
最小生成树prim算法实现 所谓生成树,就是n个点之间连成n-1条边的图形.而最小生成树,就是权值(两点间直线的值)之和的最小值. 首先,要用二维数组记录点和权值.如上图所示无向图: int map[ ...
- Highways POJ-1751 最小生成树 Prim算法
Highways POJ-1751 最小生成树 Prim算法 题意 有一个N个城市M条路的无向图,给你N个城市的坐标,然后现在该无向图已经有M条边了,问你还需要添加总长为多少的边能使得该无向图连通.输 ...
- SWUST OJ 1075 求最小生成树(Prim算法)
求最小生成树(Prim算法) 我对提示代码做了简要分析,提示代码大致写了以下几个内容 给了几个基础的工具,邻接表记录图的一个的结构体,记录Prim算法中最近的边的结构体,记录目标边的结构体(始末点,值 ...
- 图论算法(五)最小生成树Prim算法
最小生成树\(Prim\)算法 我们通常求最小生成树有两种常见的算法--\(Prim\)和\(Kruskal\)算法,今天先总结最小生成树概念和比较简单的\(Prim\)算法 Part 1:最小生成树 ...
- 最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析
最小生成树,Prim算法与Kruskal算法,408方向,思路与实现分析 最小生成树,老生常谈了,生活中也总会有各种各样的问题,在这里,我来带你一起分析一下这个算法的思路与实现的方式吧~~ 在考研中呢 ...
- 最小生成树——prim算法
prim算法是选取任意一个顶点作为树的一个节点,然后贪心的选取离这棵树最近的点,直到连上所有的点并且不够成环,它的时间复杂度为o(v^2) #include<iostream>#inclu ...
- 最小生成树--Prim算法,基于优先队列的Prim算法,Kruskal算法,Boruvka算法,“等价类”UnionFind
最小支撑树树--Prim算法,基于优先队列的Prim算法,Kruskal算法,Boruvka算法,“等价类”UnionFind 最小支撑树树 前几节中介绍的算法都是针对无权图的,本节将介绍带权图的最小 ...
- 求最小生成树(Prim算法)(1075)
Description 求出给定无向带权图的最小生成树.图的定点为字符型,权值为不超过100的整形.在提示中已经给出了部分代码,你只需要完善Prim算法即可. Input 第一行为图的顶点个数n ...
随机推荐
- CFileDialog 打开文件夹文件 保存文件夹文件
格式说明: explicit CFileDialog( BOOL bOpenFileDialog, //TRUE 为打开, FALSE 为保存 L ...
- cc2540 cc2541 低功耗实測和总结-与注意事项 - 低功耗小于10uA
CC2541 CC2540 实现超低功耗是很重要的: 我们来总结一下实现方法: 1,有定时器在跑时会一直跑在 PM2 电流在 300uA左右. 没有定时器跑后会到 PM3 , 电流会少于1 ...
- BSTR、char*和CString转换
(1) char*转换成CString 若将char*转换成CString,除了直接赋值外,还可使用CString::Format进行.例如: char chArray[] = "This ...
- //相当于深拷贝一份dataArray。这样才不会改变dataArray本身的值
//相当于深拷贝一份dataArray.这样才不会改变dataArray本身的值 NSMutableArray* commitDataArray = [NSKeyedUnarchiver unarch ...
- [Jobdu] 题目1521:二叉树的镜像
不知道怎么回事下面的代码通过了4个测试用例,还有1个测试用例始终是Runtime Error,各位帮我看一下是哪里出了问题 镜像输出两种方法,一种是递归进行调整,另外一种就是直接在先序遍历的基础上进行 ...
- Hadoop MultipleOutputs 结果输出到多个文件夹 出现数据不全,部分文件为空
如题:出现下图中的情况(设置reduceNum=5) 感觉很奇怪,排除了很久,终于发现是一个第二次犯的错误:丢了这句 this.mOutputs.close(); 加上这句,一切恢复正常!
- PHP发送短信如何实现?
最近要用php发送和接收短信,用户订单要用短信通知一类的功能,网上看了好多短信平台感觉都不靠谱. 也测试了很多代码,下面把几款PHP发送短信好用的分享给大家: PHP发送短信方法一(比较好,推荐) / ...
- Git Version recovery command introduction - git reset
reset命令有3种方式: git reset –mixed:此为默认方式,不带任何参数的git reset,即时这种方式,它回退到某个版本,只保留源码,回退commit和index信息 git re ...
- android-JSON解析
构建JSON文本 方法1. // 假设现在要创建这样一个json文本 // { // "phone" : ["12345678", "87654321 ...
- 电脑bios到底是什么?
没有哪个玩电脑的人不知道电脑bios,但是真正能明白bios是什么的?身边却没几个,甚至大多数电脑维修站的人员对bios也不够详细了解.一般人不去关心bios是因为它离我们的电脑真正使用仍有一段距离. ...