中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

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
蒙自县| 徐闻县| 兰州市| 青阳县| 平塘县| 衡阳县| 鄂尔多斯市| 金昌市| 郴州市| 莱阳市| 通辽市| 漠河县| 正蓝旗| 蓬安县| 泰州市| 上杭县| 井冈山市| 高邑县| 镇赉县| 甘孜| 固安县| 阿尔山市| 神农架林区| 湘潭县| 罗田县| 莲花县| 二手房| 攀枝花市| 小金县| 巴东县| 赫章县| 鹤岗市| 聂拉木县| 金寨县| 临颍县| 西宁市| 怀宁县| 方城县| 松潘县| 宁陕县| 米林县|