AVL平衡因子旋转
创始人
2024-11-13 01:30:44
0

AVL树是自平衡二叉搜索树,通过旋转来保持树的平衡。平衡因子是左子树高度减去右子树高度的差,当平衡因子的绝对值大于1时,需要进行旋转操作来使树重新保持平衡。 以下是一个示例代码,实现了AVL树中的插入和删除操作,并通过旋转实现了平衡维护。

class AVLTree:
    class Node:
        def __init__(self, val):
            self.val = val
            self.height = 1
            self.left = None
            self.right = None
            
    def __init__(self):
        self.root = None
        
    def height(self, node):
        if node is None:
            return 0
        return node.height

    def balance_factor(self, node):
        if node is None:
            return 0
        return self.height(node.left) - self.height(node.right)

    def left_rotate(self, node):
        right_child = node.right
        node.right = right_child.left
        right_child.left = node

        node.height = 1 + max(self.height(node.left), self.height(node.right))
        right_child.height = 1 + max(self.height(right_child.left), self.height(right_child.right))

        return right_child

    def right_rotate(self, node):
        left_child = node.left
        node.left = left_child.right
        left_child.right = node

        node.height = 1 + max(self.height(node.left), self.height(node.right))
        left_child.height = 1 + max(self.height(left_child.left), self.height(left_child.right))

        return left_child

    def insert(self, node, val):
        if node is None:
            return self.Node(val)

        if val < node.val:
            node.left = self.insert(node.left, val)
        elif val > node.val:
            node.right = self.insert(node.right, val)

        node.height = 1 + max(self.height(node.left), self.height(node.right))
        balance_factor = self.balance_factor(node)

        if balance_factor > 1:

相关内容

热门资讯

详情透视!poker红龙辅助,... 详情透视!poker红龙辅助,wepoker软件靠谱么,学习教程(竟然有挂)-哔哩哔哩1、wepok...
教你透视!pokemmo脚本辅... 教你透视!pokemmo脚本辅助器下载!其实存在有辅助软件(有挂教学)-哔哩哔哩1、玩家可以在pok...
分享透视!hhpoker可以控... 分享透视!hhpoker可以控制牌吗,wpk辅助器是真的吗,窍要教程(有挂规律)-哔哩哔哩1、进入到...
教你透视!werplan脚本!... 教你透视!werplan脚本!切实真的有辅助工具(有挂教学)-哔哩哔哩1、教你透视!werplan脚...
必备透视!wepoker买钻石... 必备透视!wepoker买钻石有用吗,wepoker有没有插件,练习教程(揭秘有挂)-哔哩哔哩小薇(...
解谜透视!德州局脚本!都是真的... 解谜透视!德州局脚本!都是真的有辅助技巧(有挂透明挂)-哔哩哔哩德州局脚本是不是有人用挂微扑克wpk...
关于透视!hhpkoer辅助器... 关于透视!hhpkoer辅助器视频,淘宝买wepoker透视有用吗,手段教程(揭秘有挂)-哔哩哔哩该...
推荐透视!cloudpoker... 推荐透视!cloudpoker作必弊!一贯真的有辅助工具(证实有挂)-哔哩哔哩;1、下载好cloud...
关于透视!德州之星扫描器,wp... 关于透视!德州之星扫描器,wpk辅助器是真的吗,资料教程(有挂技巧)-哔哩哔哩1、起透看视 wpk辅...
分享透视!werplan透视挂... 您好,werplan透视挂这款游戏可以开挂的,确实是有挂的,需要了解加去威信【136704302】很...