本节介绍了克鲁斯卡尔算法的由来,以及代码如何实现。
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的下一条边