亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

Python TreeNode如何實現樹的平衡

小樊
81
2024-08-17 16:24:40
欄目: 編程語言

在Python中實現樹的平衡可以通過實現平衡二叉樹(AVL樹)來實現。AVL樹是一種自平衡二叉搜索樹,即樹的每個節點的左子樹和右子樹的高度差不超過1。

下面是一個簡單的Python實現:

class TreeNode:
    def __init__(self, key):
        self.key = key
        self.left = None
        self.right = None
        self.height = 1

class AVLTree:
    def getHeight(self, node):
        if not node:
            return 0
        return node.height

    def getBalance(self, node):
        if not node:
            return 0
        return self.getHeight(node.left) - self.getHeight(node.right)

    def rotateRight(self, y):
        x = y.left
        T = x.right

        x.right = y
        y.left = T

        y.height = 1 + max(self.getHeight(y.left), self.getHeight(y.right))
        x.height = 1 + max(self.getHeight(x.left), self.getHeight(x.right))

        return x

    def rotateLeft(self, x):
        y = x.right
        T = y.left

        y.left = x
        x.right = T

        x.height = 1 + max(self.getHeight(x.left), self.getHeight(x.right))
        y.height = 1 + max(self.getHeight(y.left), self.getHeight(y.right))

        return y

    def insert(self, root, key):
        if not root:
            return TreeNode(key)
        elif key < root.key:
            root.left = self.insert(root.left, key)
        else:
            root.right = self.insert(root.right, key)

        root.height = 1 + max(self.getHeight(root.left), self.getHeight(root.right))

        balance = self.getBalance(root)

        if balance > 1 and key < root.left.key:
            return self.rotateRight(root)
        
        if balance < -1 and key > root.right.key:
            return self.rotateLeft(root)
        
        if balance > 1 and key > root.left.key:
            root.left = self.rotateLeft(root.left)
            return self.rotateRight(root)
        
        if balance < -1 and key < root.right.key:
            root.right = self.rotateRight(root.right)
            return self.rotateLeft(root)

        return root

使用上述代碼可以創建一個AVL樹,然后通過調用insert方法向樹中插入新節點,保持樹的平衡。

0
托克逊县| 柳州市| 大田县| 三原县| 武威市| 射洪县| 全南县| 邯郸县| 勐海县| 五指山市| 屯昌县| 西藏| 荃湾区| 勃利县| 曲阳县| 淮阳县| 吕梁市| 温泉县| 德安县| 禹城市| 崇文区| 绥滨县| 淅川县| 新郑市| 青田县| 永兴县| 龙南县| 奉化市| 安福县| 普陀区| 大兴区| 威宁| 麻栗坡县| 武定县| 太康县| 丹阳市| 丰宁| 紫金县| 四子王旗| 宽甸| 德州市|