生成广工数据结构课程设计最小生成树

广工首页  时间:2021-04-07  阅读:()

课程设计

课程名称数据结构学院_专业班级学号__________________学生姓名

指导教师

______________

2015年7月2日

1.需求分析

题目最小生成树问题

若要在n个城市之间建设通讯网络只需要架设 n-1条线路即可。如何以最低的经济代价建设这个通讯网是一个网的最小生成树问题。

要求

1 利用克鲁斯卡尔算法求网的最小生成树。

2 实现并查集。 以此表示构造生成树过程中的连通分量。3 以文本形式输出生成树中各条边以及他们的权值。输入的形式和输入值的范围十进制数 0—100。

输出的形式十进制数。

程序所能达到的功能遍历所有城市生成最小生成树。

测试数据

正确数据

城市个数3 3个城市的邻接矩阵 1,2,3;2,100,4;3,4,6

输出结果第1条路段为1――2,权值为2

第2条路段为1――3,权值为3

遍历所有城市得到最小生成树的代价为 5错误数据城市个数3;城市的邻接矩阵 -2,5,1;3,0,1;3,2,1

输出结果输入错误请重新输入

2■概要设计

数据类型定义如下typedef struct node

{int str; /*起点*/intend; /*终点*/int dis;/*距离*/

}n ode;node p[max],temp; /*p记录城市信息*/

int pre[100],rank[100];/*用于判断是否构成回路*/int n=0叩记录城市间权值*/

主程序流程如下

3■详细设计

(1) 克鲁斯卡尔算法思想基本描述

假设连通图N=(V, {E}) 贝冷最小生成树的初始状态为只有n顶点而无边的非连通图T=(V,{ }) 图中每个顶点自成一个连通分量。在E中选择代价最小的边若该边依附的顶点落在T中不同的连通分量上则将此边加入到T中,否则舍去此边而选择下一条代价最小的边。 以此类推直至T中所有顶点都在同一个连通分量上为止。

(2) 克鲁斯卡尔算法设计a.设置计数器E初值为0,记录已选中的边数。将所有边从小到大排序 存于p[]中。b.从p[]中选择一条权值最小的边检查其加入到最小生成树中是否会构成回路若是 贝吐匕边不加入生成树否则加入到生成树中计数器E累加1 。c.从E中删除此最小边转b继续执行直到k=n-1,算法结束。

判断是否回路

设置集合S,其中存放已加入到生成树中的边所连接的顶点集合当一条新的边要加入到生成树中时检查此边所连接的两个顶点是否都已经在S中若是,则表示构成回路否则若有一个顶点不在S中或者两个顶点都不在S中则

不够成回路。

/*需要的函数声明*/int mai n( ) //主程序int me nu( ) //菜单函数void create( ) //输入城市信息函数vo id judge( ) //判断是否能够生成最小生成树函数void display( ) //打印输出void s et ( ) //初始化pre[],rank[]函数void find( ) //判断是否构成回路函数void Union( ) //将能构成最小生成树的边添加到一个集合void Krushal() 〃克鲁斯算法求最小生成树

/*菜单函数*/int menu() {

int m;p rintf(". . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .2015年7月2日. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . .\n\n");p rintf(" 求最小生成树\n");prin tf("__________________________________________\n\n");p rintf(" 1输入城市之间的信息\n");prin tf(" 2判断是否能构成一个最小生成树\n");p rintf(" 3遍历所有城市生成最小生成树\n");prin tf(" 0退出\n");prin tf("__________________________________________\n\n");p rintf(" 请输入所选功能0-3\n");sea nf("%d",&m);if(m<0| |m>3)return 4;return m;

}

/*下面三个函数作用是检验当一条边添加进去是否会产生回路 */void set(int x)/*初始化*/

{p re[x]=x;ran k[x]=0;

}

/*找到这个点的祖先*/int fin d(i nt x)

{if(x!=p re[x])pre[x]=fin d(pre[x]);return pre[x];

/*将这两个数添加到一个集合里去*/void Union(i nt x,i nt y)

{x=find(x);

y=find(y);if(ran k[x]>=ran k[y])

{p re[y]=x;ran k[x]++;

}els e pre[y]=x;

}

/*克鲁斯算法求最小生成树*/void Kruskal()

{int ans=O用来记录生成最小树的权总值*/int in dex;int count=0; /*记录打印边的条数*/fo r(i=1;i<=n;i++) /*初始化数组p re[x]*/s et(i);for(i=1;i<=n;i++)

{for(j=i+1;j<=n;j++)

{p[++k].str=i;p[k].e nd=j;p[k].d is=arc s[i][j]; /*先把所有城市之间的路段看成一个边*/}

}for(i=1;i<=k;i++) /*把所有的边按从小到大进行排序*/{in dex=i;for(j=i+1;j<=k;j++) if(p[j].dis<p[i ndex].dis) in dex=j;temp=p[i nd ex];

p[i ndex]=p[i];p[i]=temp;

}for(i=1;i<=k;i++)

{if(find(p[i].s tr) !=find(p[i].end))/*如果这两点连接在一起不构成一个回路则执行下面操作

*/

{p rintf("\t 第%d条路段为 d--%d,权值为d\n",++c o unt,p[i].s tr,p[i].end,p[i].d is);/*将这条边的起点、终点打印出来*/an s+=p[i].d is; /*说明这条路段要用*/

Union(p[i].str,p[i].e nd);

}

}p rintf("\t遍历所有城市得到最小生成树的代价为 %d\n\n",ans);

}

/*输入城市信息*/void create()

{int i,j;p rintf("请输入城市的个数(1—30):\n");scanf("%d",&n);if(*=0| |n>30) {p rintf("输入错误请重新输入\n");return; }p rintf("输入%d个城市存储边(带权)的数组(数值范围 1-99,^用100表

示 ) \n",n);for(i=1;i<=n;i++)

{for(j=1;j<=n;j++)

{sea nf("%d",&arc s[i][j]);

if(arc s[i][j]<1| |arc s[i][j]>100)

{p rintf("输入错误请重新输入\n");return;

}

}

}for(i=0;i<n;i++)for(j=0;j<i;j++)if(arc s[i][j]!=arc s[j][i]) /*判断矩阵是否对称*/{p rintf("输入错误请重新输入\n");return;

}

}

/*显示生成的最小生成树*/void display( ) {if(n==0)

{p rintf("这里没有城市之间的信息\n");return;

}p rintf("遍历所有城市得到最小生成树为 \n\n\n");Krus ka l();

}

/*判断是否能够生成最小生成树*/vo id judge()

{int close[100],low[100],i,j,ans=0;/*close[j]表示离j最近的顶点 low[j]表示离j最短的距离*/int us e[100];us e[1]=1;for(i=2;i<=n;i++)

{lo w[i]=arc s[1][i]; /*初始化*/close[i]=1;us e[i]=0;

}for(i=1;i<n;i++)

{int min=100000000,k=0;for(j=2;j<=n;j++)

{if(use[j]==0&&min>low[j])/*找到最小的low[]值并记录*/

{min=low[j];k=j;

}

}for(j=2;j<=n;j++)

{if(use[j]==0&&low[j]>arcs[k][j])

{

Iow[j]=arcs[k][j]; /*修改low[]值和close]]值*/close[j]=k;

月神科技:香港CN2/洛杉矶CN2/华中电信高防vps,月付20元起

月神科技怎么样?月神科技是由江西月神科技有限公司运营的一家自营云产品的IDC服务商,提供香港安畅、香港沙田、美国CERA、华中电信等机房资源,月神科技有自己的用户群和拥有创宇认证,并且也有电商企业将业务架设在月神科技的平台上。目前,香港CN2云服务器、洛杉矶CN2云主机、华中电信高防vps,月付20元起。点击进入:月神科技官方网站地址月神科技vps优惠信息:香港安畅CN2-GIA低至20元核心:2...

打开海外主机域名商出现"Attention Required"原因和解决

最近发现一个比较怪异的事情,在访问和登录大部分国外主机商和域名商的时候都需要二次验证。常见的就是需要我们勾选判断是不是真人。以及比如在刚才要访问Namecheap检查前几天送给网友域名的账户域名是否转出的,再次登录网站的时候又需要人机验证。这里有看到"Attention Required"的提示。我们只能手工选择按钮,然后根据验证码进行选择合适的标记。这次我要选择的是船的标识,每次需要选择三个,一...

香港 E5-2650 16G 10M 900元首月 美国 E5-2660 V2 16G 100M 688元/月 华纳云

华纳云双11钜惠出海:CN2海外物理服务器终身价688元/月,香港/美国机房,免费送20G DDos防御,50M CN2或100M国际带宽可选,(文内附带测评)华纳云作为一家专业的全球数据中心基础服务提供商,总部在香港,拥有香港政府颁发的商业登记证明,APNIC 和 ARIN 会员单位。主营香港服务器、美国服务器、香港/美国OpenStack云服务器、香港高防物理服务器、美国高防服务器、香港高防I...

广工首页为你推荐
深圳市残友电子善务股份有限公司http500http://bb500.com 这个电影网站安全不?为什么?有人能告诉我吗?不懂的人表乱说浪费你我的时间谢谢苹果appstore宕机苹果appstore打不开怎么办cisco2960配置Cisco2960是二层交换机,怎么可以进入配置界面进行配置。不是说二层交换机不需要配置吗?易名网易名网交易域名是怎么收费的碧海银沙网怎样在碧海银沙网里发布图片?正大天地网正大光明是什么数字我爱e书网手机怎么下载电子书免费代理加盟怎样免费加盟代理淘宝武林官网武林外传网游国服2019年还有多少人玩?
国外虚拟主机 www二级域名 域名是什么 移动服务器租用 万网域名代理 鲁诺vps 国外永久服务器 a2hosting 轻博客 网盘申请 华为4核 777te cdn联盟 me空间社区 傲盾官网 drupal安装 彩虹云 免费邮件服务器 沈阳主机托管 smtp服务器地址 更多