首页 > 编程语言 > 详细

[算法导论]强连通分量 @ Python

时间:2015-03-17 00:25:47      阅读:993      评论:0      收藏:0      [点我收藏+]
class Graph:
    def __init__(self):
        self.V = []

class Vertex:
    def __init__(self, x):
        self.key = x
        self.color = white
        self.d = 10000
        self.f = 10000
        self.pi = None
        self.adj = []

class Solution:
    def Dfs(self, G):
        for u in G.V:
            u.color = white
            u.pi = None
        global time
        time = 0
        for u in G.V:
            if u.color == white:
                list=[u]
                self.DfsVisit(G, u, list)
                print ‘‘.join([i.key for i in list])


    def DfsVisit(self, G, u, list):
        global time
        time = time + 1
        u.d = time
        u.color = gray
        for v in u.adj:
            if v.color == white:
                list.append(v)
                v.pi = u
                self.DfsVisit(G, v, list)
        u.color = black
        time = time + 1
        u.f = time

    def GraphTransposition(self, G):
        for u in G.V:
            u.adj = (u.adj,[])

        for u in G.V:
            for v in u.adj[0]:
                v.adj[1].append(u)

        for u in G.V:
            u.adj = u.adj[1]

        return G

    def StronglyConnectedComponents(self, G):
        self.Dfs(G)
        G_Transposition = self.GraphTransposition(G)
        G_Transposition.V.sort(key=lambda v: v.f, reverse=True)
        self.Dfs(G_Transposition)



if __name__ == __main__:
    a,b,c,d,e,f,g,h = [Vertex(i) for i in [a,b,c,d,e,f,g,h]]

    a.adj = [b]
    b.adj = [c,e,f]
    c.adj = [d,g]
    d.adj = [c,h]
    e.adj = [a,f]
    f.adj = [g]
    g.adj = [f,h]
    h.adj = [h]

    G = Graph()
    G.V = [a,b,c,d,e,f,g,h]

    m = Solution()
    m.StronglyConnectedComponents(G)

 

[算法导论]强连通分量 @ Python

原文:http://www.cnblogs.com/zuoyuan/p/4343148.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!