标题:费力整出的Kruskal算法,使用小根堆和并查集,请大神指点
只看楼主
marlow
Rank: 6Rank: 6
等 级:侠之大者
威 望:2
帖 子:125
专家分:419
注 册:2016-7-18
结帖率:75%
已结贴  问题点数:10 回复次数:1 
费力整出的Kruskal算法,使用小根堆和并查集,请大神指点
程序代码:
Graph* Kruskal(Graph *T, Graph *E)
{
    int n = E->vexnum;//记录图E的顶点数量
    MinHeap temp; 
    int startroot, endroot;
    int i;

    for(i = 0; i < E->arcnum; ++i)        //初始化并查集 
        parent[i] = -1;
    inHeap(E->arcnum, E);                 //将所有边存入堆中 
    if(E->arcnum <= n - 1)
        printf("No spanning tree.\n");
    while(!IsEdgeEmpty(E)){
        temp = removeHeapMin();
        DeleteEdge(E, temp.start, temp.end);
        startroot = collaspingFind(temp.start);
        endroot = collaspingFind(temp.end);
        if(startroot != endroot){
            InsertEdge(T, temp.start, temp.end, temp.weight);
            weightedUnion(startroot, endroot);
        }
    }
    return T;
}
2017-04-09 22:40
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:7 
直接写一个属性值再读出来看看就清楚
2017-04-10 07:45



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-475952-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.987830 second(s), 7 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved