克鲁斯卡尔Kruskall算法图解

本节介绍了克鲁斯卡尔算法的由来,以及代码如何实现。

def Kruskall():
    vest=[-1]*MAXV#用vest数组代表每个顶点头上带的帽子,接入一条边,对应的顶点就要戴上相同的帽子
    E=[]#E用来存储边的信息,每条边用起点+终点+权值来表示,因为是无向图,在循环的时候设置j始终大于i,就可以保证边不重复表示了
    for i in range(g.n):#添加每一条边,因为图是邻接矩阵存储结构所以不存储值为0和INF的,这两个表示没有边
        for j in range(i+1,g.n):
            if g.edgrs[i][j]!=0 and g.edges[i][j]!=INF:
                E.append([i,j,g.edges[i][j]])

    #把这些边按照权值进行排序
    E.sort(key=itemgetter(2))

    #对每个顶点的头上带的序号进行初始化,在没有把边连起来的时候,每个顶点头上戴的帽子都是它的序号本身
    for i in range(g.n):vest[i]=i

    cnt=i#这个计数器用来判断是否把全部的边接入,如果是,那么就结束操作
    
    j=0#取E中边的下标,初始值为0

    while cnt<g.n:#计数器用来判断是否把全部的边接入,如果是,那么就结束操作
        u1,v1=E[j][0],E[j][1]#u1 v1用来表示接入边的两个庆典
        sn1=vest[u1]#sn1用来标记u1头上带的帽子
        sn2=vest[v1]#sn2用来标记v1头上带的帽子
        if sn1!=sn2:#只要头上戴的帽子不一样,就说名接入的边不能成环,就可以接入
            print("(%d.%d):%d"%(u1,v1,E[j][2]),end='')
            cnt+=1#接入的边是数量+1
            for i in range(g.n):#接入之后把接入的边的两个顶点的帽子值置为一样的,因为后来接入一条边可能要把连起来的所有边的顶点的帽子都置为一样
                if vest[i]==sn2:#将接入的边的两个顶点的帽子的值置为较小的那一个
                    vest[i]=sn1
        j+=1#取E的下一条边

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

踏歌~

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值