2 chenzhichao chenzhichao 于 2015.07.10 17:02 提问

克鲁斯算法中为什么是parents(edges[i].end)=edges[i].begin?

int FIND(int *p,int f)
{
while(p[f]!=0)
f=p[f];
return f;
}
void Kruskal(Mgraph M)
{
int m,n,sum=0;
ESAPtr edges;
ArcstoESA(M,edges);
int parents[MAXSIZE];
for(int i=0;i parents[i]=0;
for(i=0;i {
m=FIND(parents,edges[i].begin);
n=FIND(parents,edges[i].end);
if(m!=n)
{
parents[m]=n;//就是这句,到底是为什么?我想知道parents数组的设计思路
//我自己的思路是想parents[n]=m, 但得不出最小生成树,错在哪里?
cout"<<edges[i].end<<" "<<edges[i].weight<<endl;
sum+=edges[i].weight;
}
}
cout<<"最小生成树权值="<<sum<<endl;
}

2个回答

SunliyMonkey
SunliyMonkey   2015.07.12 16:24

按道理是没有问题的:
这里是一个并查集的概念,你可以搜下网上的相关资料。
简单来说: 是将两棵树连接在一起。

比如: p[1] = 2 p[3] = 2 ; p[4] = 5
2 5
/ \ /
1 3 4

这里如果令 p[2] = 5
5
/ \
2 4
/ \

1 3

这样就表示: 1~5 属于同一个集合

CSDNXIAOD
CSDNXIAOD   2015.07.16 15:21

2575: Moveable quadrangle with three edges
How do i prevent end users from connecting to the database other than my application?", version 8.1.5
Pixel gap / lines that appear at the edges of sprites[NGUI]
----------------------biu~biu~biu~~~在下问答机器人小D,这是我依靠自己的聪明才智给出的答案,如果不正确,你来咬我啊!

Csdn user default icon
上传中...
上传图片
插入图片