克鲁斯卡尔求最小生成树

twlkyao
博客专家认证
2010-05-24 09:13:36
#include <iostream>
#include <stdio.h>
#include <malloc.h>
#define MAX_TREE_SIZE 100
using namespace std;

typedef struct PTNode//结点的结构
{
char data;
int parent;
}PTNode,*PTNodeType;

typedef struct EdgeNode//边结点的结构
{
int u;
int weight;
int v;
}EdgeNode,*EdgeType;

int main()
{
EdgeType Edge;//用于存放边的信息的数组
PTNodeType Node;//用于存放顶点的信息的数组
int i,j,k,e,n,temp1,temp2,temp3;
cout<<"请输入图的边数:e"<<endl;
cin>>e;
Edge=(EdgeType)malloc(e*sizeof(EdgeNode));
cout<<"请输入图的顶点数:n"<<endl;
cin>>n;
Node=(PTNodeType)malloc(n*sizeof(PTNode));
cout<<"下面开始输入边的信息!"<<endl;
for(i=0;i<e;i++)
{
cout<<"请输入第"<<i+1<<"条边的信息:(u,weight,v)"<<endl;
cin>>Edge[i].u;
cin>>Edge[i].weight;
cin>>Edge[i].v;
}
cout<<"边的信息输入结束.下面输入顶点的信息!"<<endl;
cout<<"请按顺序输入顶点的信息!"<<endl;
for(i=0;i<n;i++)
{
cout<<"第"<<i+1<<"个顶点的信息"<<endl;
cin>>Node[i].data;
Node[i].parent=i+1;
}
for(i=0;i<e;i++)
for(j=0;j<e-1;j++)
{
if(Edge[j].weight>Edge[j+1].weight)
{
temp1=Edge[j+1].u;
temp2=Edge[j+1].weight;
temp3=Edge[j+1].v;
Edge[j+1].u=Edge[j].u;
Edge[j+1].weight=Edge[j].weight;
Edge[j+1].v=Edge[j].v;
Edge[j].u=temp1;
Edge[j].weight=temp2;
Edge[j].v=temp3;
}
}
/*for(i=0;i<e;i++)
{
cout<<Edge[i].weight<<' ';
}//测试排序 */
for(j=0,k=1;j<e && k<n;j++)
{
if(Node[Edge[j].u-1].parent!=0 || Node[Edge[j].v-1].parent!=0)//Edge[j].u和Edge[j].v树根不同
{
cout<<Node[Edge[j].u-1].data<<"-"<<Edge[j].weight<<"-"<<Node[Edge[j].v-1].data<<endl;
Node[Edge[j].u-1].parent=0;
Node[Edge[j].v-1].parent=0;
k++;
}
}
return 0;
}





为什么生成树的边会莫名其妙的少几条呢?
...全文
243 回复 打赏 收藏 转发到动态 举报
写回复
用AI写文章
回复
切换为时间正序
请发表友善的回复…
发表回复

64,637

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧