Graph 圖

Disjoint Set

class UnionFind:
    def __init__(self, size):
        self.root = [i for i in range(size)]

    def find(self, x):
        return self.root[x]

    def union(self, x, y):
        rootX = self.find(x)
        rootY = self.find(y)
        if rootX != rootY:    
            for i in range(len(self.root)):
                # 使用 rootX 當作新的根節點
                # 找到節點是以 rootY 當作根節點的,就替換成 rootX
                if self.root[i] == rootY:
                    self.root[i] = rootX

    def connected(self, x, y):
        return self.find(x) == self.find(y)

Last updated