python完整并查集的模板

class UnionFind:
    def __init__(self):
        """
        记录每个节点的父节点
        """
        self.father = {
     }
    
    def find(self, x):
        """
        查找根节点
        路径压缩
        """
        root = x

        while self.father[root] != None:
            root = self.father[root]

        # 路径压缩
        while x != root:
            original_father = self.father[x]
            self.father[x] = root
            x = original_father
         
        return root
    
    def merge(self, x, y, val):
        """
        合并两个节点
        """
        root_x,root_y = self.find(x),self.find(y)
        
        if root_x != root_y:
            self.father[root_x] = root_y

    def is_connected(self, x, y):
        """
        判断两节点是否相连
        """
        return self.find(x) == self.find(y)
    
    def add(self, x):
        """
        添加新节点
        """
        if x not in self.father:
            self.father[x] = None

你可能感兴趣的:(python,知识点记录,python,二叉树)