| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 921 人关注过本帖
标题:费力整出的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: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10609
专家分:43210
注 册:2014-5-20
收藏
得分:7 
直接写一个属性值再读出来看看就清楚
2017-04-10 07:45
快速回复:费力整出的Kruskal算法,使用小根堆和并查集,请大神指点
数据加载中...
 
   



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

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