AVL排序为什么不是原地排序?
创始人
2024-11-13 01:30:43
0

AVL排序是一种自平衡的二叉搜索树排序算法,它的操作过程需要对树的结构进行修改,因此无法满足原地排序的要求。

以下是一个示例实现AVL排序的代码,其中实现了自平衡的操作:

class Node:
    def __init__(self,val):
        self.val = val
        self.left = None
        self.right = None
        self.height = 1

class AVL:
    def getHeight(self,root):
        if not root:
            return 0
        return root.height

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

    def rightRotate(self,a):
        b = a.left
        c = b.right
        b.right = a
        a.left = c
        a.height = 1 + max(self.getHeight(a.left),self.getHeight(a.right))
        b.height = 1 + max(self.getHeight(b.left),self.getHeight(b.right))
        return b

    def leftRotate(self,a):
        b = a.right
        c = b.left
        b.left = a
        a.right = c
        a.height = 1 + max(self.getHeight(a.left),self.getHeight(a.right))
        b.height = 1 + max(self.getHeight(b.left),self.getHeight(b.right))
        return b
        
    def insert(self,root,val):
        if not root:
            return Node(val)
        elif val < root.val:
            root.left = self.insert(root.left,val)
        else:
            root.right = self.insert(root.right,val)
        root.height = 1 + max(self.getHeight(root.left),self.getHeight(root.right))
        balance = self.getBalance(root)
        if balance > 1 and val < root.left.val:
            return self.rightRotate(root)
        if balance < -1 and val > root.right.val:
            return self.leftRotate(root)
        if balance > 1 and val > root.left.val:
            root.left = self.leftRotate(root.left)
            return self.rightRotate(root)
        if balance < -1 and val < root.right.val:
            root.right = self.rightRotate(root

相关内容

热门资讯

开挂透视!pokemmo脚本辅... 开挂透视!pokemmo脚本辅助,拱趴大菠萝十三水作必弊,手段教程(证实有挂)-哔哩哔哩1、首先打开...
了解透视!wepokerplu... 了解透视!wepokerplus辅助,wepoker辅助是真的假的,机巧教程(有挂神器)-哔哩哔哩该...
推荐透视!epoker免费透视... 推荐透视!epoker免费透视脚本,wpk软件是正规的吗,绝活儿教程(竟然有挂)-哔哩哔哩1、游戏颠...
教你透视!wejoker手机版... 教你透视!wejoker手机版透视脚本,wepoker私人局透视,技法教程(揭秘有挂)-哔哩哔哩1、...
推荐透视!hhpoker是真的... 推荐透视!hhpoker是真的假的,wepoker透视app下载,方式教程(有挂辅助)-哔哩哔哩1、...
关于透视!wpk模拟器,hhp... 关于透视!wpk模拟器,hhpoker有没有作必弊挂,模板教程(有挂方式)-哔哩哔哩hhpoker有...
教你透视!wepoker看底牌... 教你透视!wepoker看底牌,wpk辅助器是真的吗,资料教程(有挂细节)-哔哩哔哩;1、很好的工具...
关于透视!wepokerplu... 关于透视!wepokerplus作必弊,wepoker辅助器免费,窍要教程(了解有挂)-哔哩哔哩1、...
总结透视!newpoker怎么... 总结透视!newpoker怎么安装脚本,wepoker有没有透视方法,妙计教程(有挂助手)-哔哩哔哩...
详情透视!wpk有那种辅助吗,... 详情透视!wpk有那种辅助吗,cloudpoker怎么开挂,指南教程(有挂详细)-哔哩哔哩cloud...