Python圖論演算法(三)——kruskal

來源:互聯網
上載者:User

標籤:python   kruskal   演算法   

edge = [[1,2,1],[1,2,3],[1,3,2],[2,3,1],[2,4,4],[3,4,2]]  #這是用邊集合表示的圖s = [[]]n = 4for i in range(n):    s.append([i+1])#print s#compare方法是為了對邊排序寫的,作為參數傳入sort,就可以排序了def compare(a,b):    if(a[2] > b[2]):        return 1    elif(a[2] < b[2]):        return -1    else:        return 0edge.sort(compare)#這就是sort()的厲害之處       for e in edge:#    print s    if s[e[0]] != s[e[1]]:        print e        for i in s[e[1]]:            if(i not in s[e[0]]):                s[e[0]].append(i)            s[e[1]] = s[e[0]]
其中涉及到集合的合并和比較。

Python圖論演算法(三)——kruskal

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.