最小生成树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 ...
随机推荐
- HTML技术简介
1.DHTML:"Dynamic HTML"动态HTML技术的简称.DHTML并不是一项新技术,而是HTML,CSS,JavaScript技术组合的术语.DHTML背后的含义是: ...
- KeCode对照表(键盘按键的获取)
KeyCode键盘对照表: http://www.cnblogs.com/furenjian/articles/2957770.html
- css布局之块上下左右居中
以下方案的通用代码: HTML code: <div class="box"> <div class="content"> <!- ...
- 系统变量写在.bash_profile和.bashrc的区别
今天配置一个代理,正儿八经的把我搞蒙了,不就是export http_porxy=xxx.xxx.xxx.xxx:xxxx 然后重启服务service network restart ,依然连接不了外 ...
- gdal 1.9+python 2.7开发环境配置
最近项目使用Cesium平台基于WegGl做web地球,其中关于地形数据有一种支持格式为terrain的地形数据.这种格式可以通过一个python工具切dem来得到. 下面记录下配置gdal+pyth ...
- 网络爬虫返回json处理数据
JSON(JavaScript Object Notation) 是一种轻量级的数据交换格式.它基于JavaScript(Standard ECMA-262 3rd Edition - Decembe ...
- Airport(未解决。。。)
Airport Time Limit: 3000/1500 MS (Java/Others) Memory Limit: 65536/65536 K (Java/Others)Total Sub ...
- Android学习笔记(十七)——使用意图调用内置应用程序
使用意图调用内置应用程序 1.创建一个新的Android项目并命名为Intents,在main.xml文件里加入两个Button: <Button android:id="@+id/b ...
- ASP.NET 母版页和内容页的加载顺序
Master 模板页Content 内容页如果希望Master页面的数据传给Content页面,请Init如果希望Content页面的数据传给Master页面,请重载Load具体细节不多说了,看下面页 ...
- java中常见的单例模式详解
很多求职者在面试过程中都被问到了单例模式,最常见的问题,比如,每种单例模式的区别是什么?哪些模式是线程安全的?你们项目里用的哪种单例模式?原来没有注意这个问题,回来赶紧打开项目查看了一下代码,才发现我 ...