- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
离散数学最小生成树
实验五
实验名称:
得到最小生成树
实验目的:
1.熟悉地掌握计算机科学技术常用的离散数学中的概念、性质和运算;通过实验提高学生编写实验报告、总结实验结果的能力;使学生具备程序设计的思想,能够独立完成简单的算法设计和分析。
2.掌握图论中的最小生成树及Prim 和 Kruskal 算法等,进一步能用它们来解决实际问题。
实验内容:
输入一个图的权矩阵,得到该图的生成树,用Kruskal算法的最小生成树,用Prim算法的最小生成树。
实验原理:
Kruskal算法
假设T中的边和顶点均涂成红色,其余边为白色。开始时G中的边均为白色。
1)将所有顶点涂成红色;
2)在白色边中,挑选一条权最小的边,使其与红色边不形成圈,将该白色边涂红;
3)重复2)直到有n-1条红色边,这n-1条红色边便构成最小生成树T的边集合。
Prim算法
假设V是图中顶点的集合,E是图中边的集合,TE为最小生成树中的边的集合,则prim算法通过以下步骤可以得到最小生成树:
1)初始化:U={u 0},TE={f}。此步骤设立一个只有结点u 0的结点集U和一个空的边集TE作为最小生成树的初始形态,在随后的算法执行中,这个形态会不断的发生变化,直到得到最小生成树为止。
2)在所有u∈U,v∈V-U的边(u,v)∈E中,找一条权最小的边(u 0,v 0),将此边加进集合TE中,并将此边的非U中顶点加入U中。此步骤的功能是在边集E中找一条边,要求这条边满足以下条件:首先边的两个顶点要分别在顶点集合U和V-U中,其次边的权要最小。找到这条边以后,把这条边放到边集TE中,并把这条边上不在U中的那个顶点加入到U中。这一步骤在算法中应执行多次,每执行一次,集合TE和U都将发生变化,分别增加一条边和一个顶点,因此,TE和U是两个动态的集合,这一点在理解算法时要密切注意。
3)如果U=V,则算法结束;否则重复步骤2。可以把本步骤看成循环终止条件。我们可以算出当U=V时,步骤2共执行了n-1次(设n为图中顶点的数目),TE中也增加了n-1条边,这n-1条边就是需要求出的最小生成树的边。
实验结果:
附:程序源代码:
#includeiostream.h
#includestring.h
main()
{
system(color 9c);
cout请输入图的点数:\n;
int n;
cinn;
char c1=a;
cout系统自动生成点为:\n;
int i,j,k;
coutc1;
for(i=1;in;i++)
cout,(char)(c1+i);
int a[n][n];
cout\n请输入图的权矩阵:\n;
for(i=0;in;i++)
for(j=0;jn;j++)
cina[i][j];
cout\n\n此图的邻接矩阵为:\n ;
for(i=0;in;i++)
cout(char)(c1+i) ;
coutendl;
for(i=0;in;i++)
{
cout(char)(c1+i) ;
for(j=0;jn;j++)
if(a[i][j])
cout1 ;
else
cout0 ;
coutendl;
}
int m=0;k=0;
for(i=0;in;i++)
for(j=0;jn;j++)
if(a[i][j]ij)
m++;
int b[m][3];
for(i=0;in;i++) //找出边和权
for(j=0;jn;j++)
if(a[i][j]ij)
{
b[k][0]=i;
b[k][1]=j;
b[k++][2]=a[i][j];
}
int t;
for(i=0;im-1;i++) //排序
for(j=i+1;jm;j++)
if(b[i][2]b[j][2])
for(k=0;k3;k++)
{
t=b[i][k];
b[i][k]=b[j][k];
b[j][k]=t;
}
for(i=0;im;i+
文档评论(0)