如何实现一个二叉搜索树

实现一个二叉搜索树(Binary Search Tree, BST)主要涉及定义树的结构、插入新节点、搜索节点、以及可能的其他操作,如删除节点、遍历树等。下面是一个简单的二叉搜索树的实现示例,使用Python语言:

定义树节点

首先,我们需要定义树的节点,每个节点包含一个值和两个指向其子节点的引用(左子节点和右子节点)。

 

python复制代码

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

定义二叉搜索树

然后,我们可以定义二叉搜索树类,并实现插入、搜索和遍历等方法。

 

python复制代码

class BinarySearchTree:
def __init__(self):
self.root = None
def insert(self, key):
"""
向二叉搜索树中插入一个新节点
"""
if self.root is None:
self.root = TreeNode(key)
else:
self._insert_recursive(self.root, key)
def _insert_recursive(self, root, key):
"""
递归地插入新节点
"""
if key < root.val:
if root.left is None:
root.left = TreeNode(key)
else:
self._insert_recursive(root.left, key)
else:
if root.right is None:
root.right = TreeNode(key)
else:
self._insert_recursive(root.right, key)
def search(self, key):
"""
在二叉搜索树中搜索一个节点
"""
return self._search_recursive(self.root, key)
def _search_recursive(self, root, key):
"""
递归地搜索节点
"""
if root is None or root.val == key:
return root
if key < root.val:
return self._search_recursive(root.left, key)
return self._search_recursive(root.right, key)
def inorder_traversal(self):
"""
中序遍历二叉搜索树
"""
self._inorder_traversal_recursive(self.root)
def _inorder_traversal_recursive(self, root):
"""
递归地执行中序遍历
"""
if root:
self._inorder_traversal_recursive(root.left)
print(root.val, end=' ')
self._inorder_traversal_recursive(root.right)
# 使用示例
bst = BinarySearchTree()
bst.insert(50)
bst.insert(30)
bst.insert(20)
bst.insert(40)
bst.insert(70)
bst.insert(60)
bst.insert(80)
print("中序遍历输出:")
bst.inorder_traversal() # 应该输出 20 30 40 50 60 70 80
print("搜索 60:", bst.search(60) is not None) # 应该输出 True

这个简单的二叉搜索树实现包括了插入、搜索和中序遍历功能。你可以根据需要扩展其他功能,如删除节点、计算树的高度、检查树是否平衡等。

注意,二叉搜索树在最坏的情况下(如插入的键已经是有序的)会退化为链表,导致搜索、插入和删除操作的时间复杂度退化到O(n)。为了保持较好的性能,可能需要考虑使用其他平衡二叉树,如AVL树或红黑树。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/45951.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

maven的settings.xml无法正确配置本地仓库路径

因为以前使用过新版的maven&#xff0c;现在要换个版本使用。 在配置新的本地仓库路径的时候突然发现居然idea居然识别不了我settings.xml里面配置的路径。 我很是震惊&#xff0c;明明之前一直都是这样子配置的。怎么突然间不行了。当我冥思苦想&#xff0c;在网上搜寻资料无果…

WPF学习(5) -- WPF绑定

一、双向绑定 1.代码示例 <Window x:Class"学习.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expres…

在 MATLAB 中,如何高效地处理大规模矩阵运算以提高程序的运行速度?

在 MATLAB 中&#xff0c;可以采用以下一些方法来高效地处理大规模矩阵运算以提高程序的运行速度&#xff1a; 避免使用循环&#xff1a;MATLAB 是一种矢量化编程语言&#xff0c;通过使用矢量和矩阵操作&#xff0c;可以避免使用循环来处理矩阵运算。避免循环可以大大提高程序…

[论文阅读]MaIL: Improving Imitation Learning with Mamba

Abstract 这项工作介绍了mamba模仿学习&#xff08;mail&#xff09;&#xff0c;这是一种新颖的模仿学习&#xff08;il&#xff09;架构&#xff0c;为最先进的&#xff08;sota&#xff09;变换器策略提供了一种计算高效的替代方案。基于变压器的策略由于能够处理具有固有非…

阿里云产品流转

本文主要记述如何使用阿里云对数据进行流转&#xff0c;这里只是以topic流转&#xff08;再发布&#xff09;为例进行说明&#xff0c;可能还会有其他类型的流转&#xff0c;不同服务器的流转也可能会不一样&#xff0c;但应该大致相同。 1 创建设备 具体细节可看&#xff1a;…

LangChain —— Prompt Templates —— How to use few shot examples in chat models

文章目录 一、概述二、固定示例 Fixed Example 一、概述 本指南介绍了如何使用示例输入和输出提示 chat model。为模型提供几个这样的例子被称为 few-shotting&#xff0c;这是一种简单而强大的方法来指导生成&#xff0c;在某些情况下可以大大提高模型性能。 对于如何最好地进…

Spring源码中的模板方法模式

1. 什么是模板方法模式 模板方法模式&#xff08;Template Method Pattern&#xff09;是一种行为设计模式&#xff0c;它在操作中定义算法的框架&#xff0c;将一些步骤推迟到子类中。模板方法让子类在不改变算法结构的情况下重新定义算法的某些步骤。 模板方法模式的定义&…

驱动LSM6DS3TR-C实现高效运动检测与数据采集(8)----中断获取FIFO数据并应用MotionFX库解析空间坐标

驱动LSM6DS3TR-C实现高效运动检测与数据采集.8--中断获取FIFO数据并应用MotionFX库解析空间坐标 概述视频教学样品申请源码下载开启LED开启INT中断参考驱动程序中断读取传感器数据主程序演示 概述 本文将探讨如何使用中断机制获取FIFO数据并应用MotionFX库解析空间坐标。Motio…

React Native Android 应用开发、调试与发布深度指南

React Native 是构建跨平台移动应用的强大工具。本指南将深入探讨使用 React Native 开发、调试和发布 Android 应用的各个方面&#xff0c;为您提供全面的指导。 1. 环境准备 Node.js 和 npm/yarn: 确保您的系统中安装了 Node.js 和 npm (Node Package Manager) 或 yarn。您…

在 PostgreSQL 里如何处理数据的索引碎片整理的自动化?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 PostgreSQL 中数据索引碎片整理的自动化处理 PostgreSQL 中数据索引碎片整理的自动化处理 在数据库管…

接口基础知识2:http通信的组成

课程大纲 一、http协议 HTTP&#xff08;Hypertext Transfer Protocol&#xff0c;超文本传输协议&#xff09;是互联网中被使用最广的一种网络协议&#xff0c;用于客户端与服务器之间的通信。 HTTP协议定义了一系列的请求方法&#xff0c;例如 GET、POST、PUT、DELETE 等&…

特惠电影票api安全性如何评测

评测特惠电影票API的安全性是确保用户数据安全和系统稳定运行的关键步骤。以下是评测特惠电影票API安全性的一些方法和步骤&#xff1a; ### 1. **认证和授权** - **JWT认证**&#xff1a;使用JSON Web Token (JWT) 进行用户身份验证和授权&#xff0c;确保只有合法用户可以访…

Ubuntu搭建Android架构so库交叉编译环境

目录 前言一、下载NDK并安装二、安装NDK三、配置交叉编译工具链四、编写交叉编译脚本 前言 需要将一些源码编译成Android可用的架构的so库 一、下载NDK并安装 https://developer.android.google.cn/ndk/downloads/ 二、安装NDK 将下载下来的android-ndk-r23b-linux.zip解压…

uniapp内置组件scroll-view案例解析

参考资料 文档地址&#xff1a;https://uniapp.dcloud.net.cn/component/scroll-view.html 官方给的完整代码 <script>export default {data() {return {scrollTop: 0,old: {scrollTop: 0}}},methods: {upper: function(e) {console.log(e)},lower: function(e) {cons…

Python面试题:在 Python 中,如何实现一个 LRU(最近最少使用)缓存?

在 Python 中&#xff0c;可以使用 collections.OrderedDict 或 functools.lru_cache 来实现一个 LRU&#xff08;最近最少使用&#xff09;缓存。functools.lru_cache 是一个内置装饰器&#xff0c;可以直接用于缓存函数的结果。而如果你想实现一个自定义的 LRU 缓存&#xff…

【SVPWM】空间矢量调制

SVPWM仿真模型 扇区315462 切换时间马鞍波 三角载波和马鞍波比较 三相电压 FFT分析 参考文献&#xff1a; 现代永磁同步电机控制原理及MATLAB仿真.袁雷.

live555关于RTSP协议交互流程

RTP在和h264 RTP在和h265 RTP载荷AAC live555闭环双向链表 概要 rtsp在交互的过程中用到很多协议:tcp,udp,rtp,rtcp,sdp等协议&#xff1b;该篇文章主要分析在live555中这些协议是什么时候被创建的&#xff0c;什么时候被使用的等协议相关流程。 TCP&#xff1a;服务器与客…

WPF学习(3) -- 控件模板

一、操作过程 二、代码 <Window x:Class"学习.MainWindow"xmlns"http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x"http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d"http://schemas.microsoft.com/expressio…

树莓派pico入坑笔记,esp01/01s使用

目录 关于树莓派pico和circuitpython的更多玩法&#xff0c;请看树莓派pico专栏 说明 关于at指令 WiFi的at指令 UDP的at指令 样例程序 调试助手端输入指令 sta端程序 效果 进阶使用 库函数说明 样例代码 关于树莓派pico和circuitpython的更多玩法&#xff0c;请看树…

【随手记】python大规模数据读取

题目是MT3055 交换排列 python大规模数据读取用这个sys.stdin.read。 import sys input sys.stdin.read data input().split()这个是题解。 import heapqclass UnionFind:def __init__(self, size):self.parent list(range(size))def find(self, x):if self.parent[x] x:…