当前位置: 首页 > news >正文

Python算法——平衡二叉树(AVL)

Python中的平衡二叉搜索树(AVL树)算法详解

平衡二叉搜索树(AVL树)是一种自平衡的二叉搜索树,它通过在插入或删除节点时进行旋转操作来保持树的平衡性。在AVL树中,任何节点的两个子树的高度差(平衡因子)最多为1。这种平衡性质确保了AVL树的高度始终是对数级别,使得查找、插入和删除等操作的时间复杂度保持在O(log n)。在本文中,我们将深入讨论AVL树的原理,并提供Python代码实现。

AVL树的节点定义

首先,我们定义AVL树的节点类:

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

AVL树的节点除了包含值之外,还记录了节点的高度。这个高度信息是维持平衡的关键。

插入操作

插入操作是在AVL树中插入新节点的过程,同时需要保持树的平衡。插入后,我们需要更新节点的高度,并进行旋转操作来恢复平衡。

def insert(root, key):if root is None:return AVLNode(key)if key < root.key:root.left = insert(root.left, key)elif key > root.key:root.right = insert(root.right, key)# 更新节点的高度root.height = 1 + max(get_height(root.left), get_height(root.right))# 获取平衡因子balance = get_balance(root)# 进行旋转操作来恢复平衡# 左旋if balance > 1 and key < root.left.key:return rotate_right(root)# 右旋if balance < -1 and key > root.right.key:return rotate_left(root)# 左右双旋if balance > 1 and key > root.left.key:root.left = rotate_left(root.left)return rotate_right(root)# 右左双旋if balance < -1 and key < root.right.key:root.right = rotate_right(root.right)return rotate_left(root)return root

删除操作

删除操作是在AVL树中删除节点的过程,同时需要保持树的平衡。删除后,我们需要更新节点的高度,并进行旋转操作来恢复平衡。

def delete(root, key):if root is None:return rootif key < root.key:root.left = delete(root.left, key)elif key > root.key:root.right = delete(root.right, key)else:# 节点有一个或没有子节点if root.left is None:return root.rightelif root.right is None:return root.left# 节点有两个子节点,找到右子树的最小节点root.key = find_min(root.right).key# 删除右子树的最小节点root.right = delete(root.right, root.key)# 更新节点的高度root.height = 1 + max(get_height(root.left), get_height(root.right))# 获取平衡因子balance = get_balance(root)# 进行旋转操作来恢复平衡# 左旋if balance > 1 and get_balance(root.left) >= 0:return rotate_right(root)# 右旋if balance < -1 and get_balance(root.right) <= 0:return rotate_left(root)# 左右双旋if balance > 1 and get_balance(root.left) < 0:root.left = rotate_left(root.left)return rotate_right(root)# 右左双旋if balance < -1 and get_balance(root.right) > 0:root.right = rotate_right(root.right)return rotate_left(root)return root

辅助函数

为了实现插入和删除操作,我们需要一些辅助函数:

def get_height(node):if node is None:return 0return node.heightdef get_balance(node):if node is None:return 0return get_height(node.left) - get_height(node.right)def rotate_left(z):y = z.rightT2 = y.left# 执行左旋y.left = zz.right = T2# 更新节点的高度z.height = 1 + max(get_height(z.left), get_height(z.right))y.height = 1 + max(get_height(y.left), get_height(y.right))return ydef rotate_right(y):x = y.leftT2 = x.right# 执行右旋x.right = yy.left = T2# 更新节点的高度y.height = 1 + max(get_height(y.left), get_height(y.right))x.height = 1 + max(get_height(x.left), get_height(x.right))return x

示例

创建一个AVL树并演示插入和删除操作:

# 创建空树
avl_root = None# 插入操作
keys_to_insert = [50, 30, 70, 20, 40, 60, 80]
for key in keys_to_insert:avl_root = insert(avl_root, key)# 中序遍历查看结果
def inorder_traversal_avl(root):if root is not None:inorder_traversal_avl(root.left)print(f"({root.key}, {get_balance(root)})", end=" ")inorder_traversal_avl(root.right)print("中序遍历结果:", end=" ")
inorder_traversal_avl(avl_root)# 删除操作
delete_key = 30
avl_root = delete(avl_root, delete_key)print("\n删除节点 30 后中序遍历结果:", end=" ")
inorder_traversal_avl(avl_root)
输出结果:
中序遍历结果: (20, 1) (30, 0) (40, 0) (50, -1) (60, 0) (70, 0) (80, 0) 
删除节点 30 后中序遍历结果: (20, 1) (40, 0) (50, 0) (60, 0) (70, 0) (80, 0) 

这表示插入和删除操作都能够保持AVL树的平衡。AVL树通过自平衡的方式,保证了树的高度始终是对数级别,使得查找、插入和删除等操作的时间复杂度保持在O(log n)。通过理解其原理和实现,您将能够更好地应用AVL树解决实际问题。

相关文章:

Python算法——平衡二叉树(AVL)

Python中的平衡二叉搜索树&#xff08;AVL树&#xff09;算法详解 平衡二叉搜索树&#xff08;AVL树&#xff09;是一种自平衡的二叉搜索树&#xff0c;它通过在插入或删除节点时进行旋转操作来保持树的平衡性。在AVL树中&#xff0c;任何节点的两个子树的高度差&#xff08;平…...

公开可用的API 合集

这是一个开源项目列表&#xff0c;收录了一些公开可用、无需注册或认证即可使用的API接口。 这个项目解决了开发者们在寻找合适的API时遇到的各种困难&#xff0c;如无法快速定位、难以筛选等问题&#xff0c;为他们提供了便捷的一站式查询服务。 项目是“public-apis”&…...

单片机编程原则

多任务编程的概念 方式一&#xff1a;实时操作系统&#xff08;不建议新手使用&#xff09; 方式二 &#xff1a;裸机多任务模型 逻辑多任务的基本原理 把三个任务分别分为一个一个的片段 然后先执行任务一的第一个切片 执行第二个任务的第一个片段 执行第三个任务的第一个片…...

开源短剧付费变现小程序源码系统+在线开通会员+在线充值 带完整的搭建教程

说起微短剧&#xff0c;相信大家都不会陌生。相比传统网剧冗长的剧情&#xff0c;微短剧最大的看点&#xff0c;是时长短、高浓缩&#xff0c;顺应了当下用户娱乐时间碎片化趋势。其故事题材多为赘婿、霸道总裁、穿越、重生等看似夸张、无厘头&#xff0c;但却非常“上头”的虚…...

基于Python机器学习、深度学习技术提升气象、海洋、水文领域实践应用能力

Python是功能强大、免费、开源&#xff0c;实现面向对象的编程语言&#xff0c;能够在不同操作系统和平台使用&#xff0c;简洁的语法和解释性语言使其成为理想的脚本语言。除了标准库&#xff0c;还有丰富的第三方库&#xff0c;Python在数据处理、科学计算、数学建模、数据挖…...

电商平台为什么需要及时部署ssl证书?

电商平台为什么需要及时部署ssl证书&#xff1f; 21世纪以来&#xff0c;互联网技术得到了快速的发展和应用上的普及&#xff0c;为生活、工作、学习都带来了巨大的变化。现代社会中&#xff0c;快节奏的生活让人们的购物方式也发生了极大的转变&#xff0c;逐渐由线下转为了线…...

卡码网语言基础课 | 12. 位置互换

通过本次练习&#xff0c;将要学习到以下C知识点&#xff1a; 位置互换交换变量字符串 题目&#xff1a;给定一个长度为偶数位的字符串&#xff0c;请编程实现字符串的奇偶位互换。 奇偶位互换是指字符串的奇数位和偶数位相互交换位置 即&#xff1a;第一位和第二位交换&…...

用DOM来读取XML时要注意的一些概念

2023年11月15日&#xff0c;周三下午 在 DOM&#xff08;文档对象模型&#xff09;中&#xff0c;有一些重要的概念和术语&#xff1a; 文档对象&#xff08;Document Object&#xff09;&#xff1a;表示整个 XML 文档的根节点&#xff0c;它是 DOM 树的入口点。元素节点&…...

openresty安装配置,执行shell脚本

下载并解压 OpenResty 源代码&#xff1a; bashCopy code wget https://openresty.org/download/openresty-1.19.9.1.tar.gz tar -zxvf openresty-1.19.9.1.tar.gz cd openresty-1.19.9.1 运行 ./configure 并指定安装路径&#xff1a; bashCopy code ./configure --prefix…...

解决Dockerfile中 Could not initialize class sun.awt.X11FontManager错误

Dockerfile中增加命令 RUN yum install dejavu-sans-fonts fontconfig -y如果您使用的是基于Alpine Linux的发行版&#xff0c;可以使用apk命令来安装DejaVu Sans字体和fontconfig工具 RUN apk update RUN apk add ttf-dejavu fontconfig...

Kubernetes(k8s)进阶

文章目录 Kubernetes进阶一、Namespace&#xff08;名称空间&#xff09;1.namespace介绍2.管理namespace查看namespace创建namespaceyaml文件配置namespace 二、Pod&#xff08;最小基本部署单元&#xff09;1.pod介绍2.管理pod创建并运行pod查看pod信息访问pod删除podyaml文件…...

[Vue 配置] Vite + Vue3 项目配置和使用 NProgress

文章归档&#xff1a;https://www.yuque.com/u27599042/coding_star/mfmsrf9tz98ox3qg 安装 pnpm i nprogress配置 NProgress 其他更多可参考&#xff0c;仓库地址&#xff1a;https://github.com/rstacruz/nprogress 在 src/config/nprogress.js 中进行配置 是否展示右上角圆…...

Android MQTT开发之 Hivemq MQTT Client

使用一个开源库&#xff1a;hivemq-mqtt-client&#xff0c;这是Java生态的一个MQTT客户端框架&#xff0c;需要Java 8&#xff0c;Android上使用的话问题不大&#xff0c;需要一些额外的配置&#xff0c;下面列出了相关的配置&#xff0c;尤其是 packagingOptions&#xff0c;…...

【Maven教程】(十一):使用 Maven 构建 Web应用 —— 使用 jetty-maven-plugin 进行测试、使用 Cargo 实现自动化部署~

Maven 使用 Maven 构建 Web应用 1️⃣ Web 项目的目录结构2️⃣ account-service2.1 account-service的 POM2.2 account-service 的主代码 3️⃣ account-web3.1 account-web 的POM3.2 account-web 的主代码 4️⃣ 使用 jetty-maven-plugin 进行测试5️⃣ 使用 Cargo 实现自动…...

番外 2 : LoadRunner 的安装以及配置

LoadRunner 的安装以及配置教程 一 . 配置 IE 浏览器二 . 安装 LoadRunner 工具三 . 修改默认浏览器的配置四 . 设置 LoadRunner 能够获取本地资源 Hello , 大家好 , 又给大家带来新的专栏喽 ~ 这个专栏是专门为零基础小白从 0 到 1 了解软件测试基础理论设计的 , 虽然还不足以…...

win10正确配置tensorRT环境

目的 使用tensorRT进行网络模型部署&#xff0c;加快推理速度 方法 安装tensorRT的过程需要对各种组件的版本进行匹配 前置安装套件有&#xff1a; 1、CUDA 2、cuDNN 3、pyCUDA 4、tensorflow或pytorch 主要记录tensorRT安装: tensorRT安装配置查询 步骤: 1、去tensorRT官网…...

C++初阶-模板初阶

模板初阶 一、泛型编程二、函数模板2.1函数模板概念2.2函数模板格式2.3函数模板的原理2.4函数模板的原理2.5模板参数的匹配原则 三、类模板3.1类模板的定义格式3.2类模板的实例化 一、泛型编程 如何实现一个通用的交换函数呢&#xff1f; void Swap(int& left, int& …...

基于Python实现汽车销售数据可视化【500010086】

导入模块 import numpy as np import pandas as pd import plotly.graph_objects as go import plotly.express as px获取数据 df1 pd.read_excel(r"./data/中国汽车总体销量.xlsx") print(df1.head(5))df1.info()df1[年份] df1[时间].dt.year df1[月份] df1[时…...

dist.init_process_group() 卡住超时导致报错

在跑模型是遇到一个问题&#xff1a; import torch.distributed as dist dist.init_process_group(backend"nccl", init_methodtcp://localhost:%d % tcp_port, ranklocal_rank, world_sizenum_gpus)程序卡在这一步一动不动。. 解决办法一&#xff1a; 我看网上有人…...

RESTFul API:真是让人又爱又恨

RESTFul API是一种广泛使用的Web服务设计风格&#xff0c;它以资源为中心&#xff0c;通过HTTP方法来操作这些资源。然而&#xff0c;尽管RESTFul架构风格在许多情况下都非常有用&#xff0c;但在实际应用中&#xff0c;我们也发现了一些不足之处。本文将详细阐述这些问题&…...

科学机器学习工作流:融合物理与数据驱动的气候建模新范式

1. 项目概述&#xff1a;当气候科学遇见机器学习工作流 如果你和我一样&#xff0c;在气候科学或者更广泛的科学计算领域摸爬滚打多年&#xff0c;一定经历过这样的时刻&#xff1a;面对一个物理过程复杂、计算成本高昂的模型&#xff0c;既想引入数据驱动的新方法提升效率&…...

XUnity.AutoTranslator:打破语言障碍,让Unity游戏实时翻译变得简单

XUnity.AutoTranslator&#xff1a;打破语言障碍&#xff0c;让Unity游戏实时翻译变得简单 【免费下载链接】XUnity.AutoTranslator 项目地址: https://gitcode.com/gh_mirrors/xu/XUnity.AutoTranslator 还在为看不懂外语游戏而烦恼吗&#xff1f;XUnity.AutoTranslat…...

Color与Linear Color

简单来说&#xff1a;Color 是给“人眼”看的颜色&#xff0c;而 Linear Color 是给“电脑&#xff08;引擎&#xff09;”算的纯粹数据。在虚幻引擎&#xff08;以及所有现代 3D 渲染引擎&#xff09;中&#xff0c;区分这两者是非常核心的图形学概念。下面是它们具体的区别&a…...

3.RAG

一、RAG初识&#xff1a; RAG(Retrieval-Augmented Generation&#xff0c;检索增强生成)是一种将 信息检索与文本生成 相结合的技术框架。它通过以下流程解决大模型(LLM)的“知识盲区”问题: 用户问题->从知识库检索相关文档->将文档作为上下文输入LLM->生成精准答…...

独立游戏开发者如何用Tap广告联盟实现首月变现?我的Unity激励视频接入与调优心得

独立游戏开发者的Tap广告联盟实战指南&#xff1a;从零到首笔收益的完整路径当我在Steam上发布第一款独立游戏时&#xff0c;曾天真地认为"酒香不怕巷子深"。直到账户余额持续三个月停留在两位数&#xff0c;才意识到商业化设计的重要性。作为小型团队&#xff0c;我…...

vue2-admin-lte vs 原生AdminLTE:为什么选择Vue.js重构后台系统?

vue2-admin-lte vs 原生AdminLTE&#xff1a;为什么选择Vue.js重构后台系统&#xff1f; 【免费下载链接】vue2-admin-lte :bar_chart: adminLTE to vuejs v2.x converting project 项目地址: https://gitcode.com/gh_mirrors/vu/vue2-admin-lte vue2-admin-lte是基于V…...

国密滑块登录实战:SM2+SM4密码链路全解析

1. 这不是“加个密”那么简单&#xff1a;滑块登录里藏着的国密链路真相你有没有试过&#xff0c;在某个政务类App或银行类Web端拖动滑块完成登录后&#xff0c;页面瞬间跳转&#xff0c;但控制台Network面板里却找不到任何明文密码字段&#xff1f;甚至抓包发现&#xff0c;提…...

模拟神经计算电路:噪声与非均匀性挑战下的网络架构优化与再训练策略

1. 项目概述与核心挑战在材料科学、药物发现乃至自动驾驶的实时决策中&#xff0c;我们常常需要模型以极高的速度处理海量数据&#xff0c;进行预测或推理。传统的数字计算机在执行这类任务时&#xff0c;面临着功耗和计算延迟的瓶颈。于是&#xff0c;一个极具吸引力的替代方案…...

基于图神经网络的机器学习有限区域模型:边界处理与图结构设计实战

1. 项目概述与核心挑战最近几年&#xff0c;机器学习天气预测&#xff08;MLWP&#xff09;的进展让人有点兴奋&#xff0c;又有点眼花缭乱。从全球尺度的大模型到区域性的精细化预报&#xff0c;数据驱动的方法正在重新定义我们对大气模拟的理解。作为一名长期混迹在气象和计算…...

MobX进阶教程:如何自定义observables和扩展MobX功能

MobX进阶教程&#xff1a;如何自定义observables和扩展MobX功能 【免费下载链接】MobX-Docs-CN MobX 中文文档 项目地址: https://gitcode.com/gh_mirrors/mo/MobX-Docs-CN MobX是一个强大的状态管理库&#xff0c;它让状态管理变得简单且可扩展。在掌握基础用法后&…...