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

数据结构之二叉搜索树(Binary Search Tree)

数据结构可视化演示链接,也就是图片演示的网址


系列文章目录

数据结构之AVL Tree
数据结构之B树和B+树
数据结构之Radix和Trie


文章目录

    • 系列文章目录
    • 示例图
    • 定义
    • 二叉搜索树满足的条件
    • 应用场景


示例图

二叉

在这里插入图片描述

线形(顺序插入就变成了线性树,例如插入顺序为:1,2,3,4,5,6)

在这里插入图片描述


定义

二叉搜索树也是一种树,适用与一般二叉树的全部操作,但二叉搜索树能够实现数据的快速查找。

二叉搜索树满足的条件

  1. 非空左子树的所有键值小于其根节点的键值
  2. 非空右子树的所有键值大于其根节点的键值
  3. 左右子树都是二叉搜索树

应用场景

如果是没有退化称为链表的二叉树,查找效率就是lgn,效率不错,但是一旦退换为链表,要么使用平衡二叉树,或者之后的RB树(红黑树),因为链表就是线性的查找效率。

http://www.lryc.cn/news/276983.html

相关文章:

  • Spring Boot自定义启动Banner在线生成工具
  • Android Studio导入项目 下载gradle很慢或连接超时,提示:Read timed out---解决方法建议收藏!
  • 汽车标定技术(十五)--FETK如何帮助Aurix实现快速原型、标定测量功能(1)
  • linux项目部署(jdk,tomcat,mysql,nginx,redis)
  • Unity | 渡鸦避难所-6 | 有限状态机控制角色行为逻辑
  • 数据库参数 PGA_AGGREGATE_LIMIT 限制进程大小
  • 208.【2023年华为OD机试真题(C卷)】停车场车辆统计(贪心算法实现-JavaPythonC++JS实现)
  • JS 作用域和预解析
  • 各种锁的概述
  • 【docker笔记】Docker容器数据卷
  • 大前端nestjs入门教程系列(四):如何nestjs整合mysql数据库
  • Android studio环境配置
  • 017、使用包、单元包及模块来管理日渐复杂的项目
  • Git提交规范详解
  • 线程与UI操作
  • ELK企业级日志系统分析系统
  • 11.23 校招 实习 内推 面经
  • Python战机
  • 外包做了5个月,技术退步一大半了。。。
  • 设计模式的艺术P1基础—2.2 类与类的UML图示
  • PCB 的正片、负片那些事儿
  • QT应用篇:QT解析与生成XML文件的四种方式
  • Android 正圆
  • C#,入门教程(13)——字符(char)及字符串(string)的基础知识
  • Tracert 与 Ping 程序设计与实现(2024)
  • 浅谈接口自动化测试
  • Hyperledger Fabric 核心概念与组件
  • 【C语言题解】 | 101. 对称二叉树
  • Baumer工业相机堡盟工业相机如何通过NEOAPI SDK实现相机掉线自动重连(C#)
  • [Vulnhub靶机] DriftingBlues: 5