chenzhichao 2015-07-10 09:02 采纳率: 50%
浏览 1418

克鲁斯算法中为什么是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;
}

  • 写回答

1条回答

  • SunliyMonkey 2015-07-12 08: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 属于同一个集合

    评论

报告相同问题?

悬赏问题

  • ¥15 YoloV5 第三方库的版本对照问题
  • ¥15 请完成下列相关问题!
  • ¥15 drone 推送镜像时候 purge: true 推送完毕后没有删除对应的镜像,手动拷贝到服务器执行结果正确在样才能让指令自动执行成功删除对应镜像,如何解决?
  • ¥15 求daily translation(DT)偏差订正方法的代码
  • ¥15 js调用html页面需要隐藏某个按钮
  • ¥15 ads仿真结果在圆图上是怎么读数的
  • ¥20 Cotex M3的调试和程序执行方式是什么样的?
  • ¥20 java项目连接sqlserver时报ssl相关错误
  • ¥15 一道python难题3
  • ¥15 牛顿斯科特系数表表示