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

C++ 渗透 数据结构中的二叉搜索树

欢迎来到干货小仓库

"沙漠尽头必是绿洲。"

                                --面对技术难题时,坚持终会看到希望。

1.二叉搜索树的概念

二叉搜索树又称二叉排序树,它或者是一颗空树,或者是具有以下性质的二叉树:

a、若它的左子树不为空,则左子树上所有节点的值都小于根节点的值。

b、若它的右子树不为空,则右子树上所有节点的值都大于根节点的值。

c、它的左右子树也分别为二叉搜索树

2.二叉搜索树的查找

①从根开始比较,若查找的目标值比根大则往右子树中查找,比根小则往左边找。

②最多查找高度次,走到空还没找到,则这个值不存在。

循坏实现和递归实现

3.二叉搜索树的插入

a、若树为空,则直接新增节点,赋值给根(root)。

b、树不为空,则按二叉搜索树的规则走,比根节点大的 往右子树找,反之往左子树找,找到插入位置后,与该位置的父节点比较,看链接在左子树还是右子树。

c、当插入的数据,树中已有则插入失败。

4.二叉搜索树的删除

首先遍历二叉搜索树,看是否存在删除的值,不存在则直接返回false。

存在:主要分为两种情况

①该节点其左子树/右子树其中一个不为空或者都为空

②该节点其左子树和右子树都不为空。

第一种情况

第二种情况:要删除的节点的左右子树都不为空

方式一:与左子树的最右节点交换(左子树最大值)

方式二:与右子树的最左节点交换(右子树最小值)

非递归版本

//非递归
bool Erase(const K& key)
{Node* cur = _root;Node* parent = nullptr;while (cur){if (cur->_key > key){parent = cur;cur = cur->_left;}else if (cur->_key < key){parent = cur;cur = cur->_right;}//找到删除元素了else{	//左子树为空if (cur->_left == nullptr){	//要删除的数据是根节点if (cur == _root)_root = _root->_right;else{if (parent->_right == cur)parent->_right = cur->_right;elseparent->_left = cur->_right;}}//右子树为空else if (cur->_right == nullptr){	//要删除的数据是根节点if (cur == _root){_root = _root->_left;}else{if (parent->_right == cur)parent->_right = cur->_left;elseparent->_left = cur->_left;}}//左右都不为空else{//找左子树的最大值(其右子树必为空)parent = cur;Node* leftMax = cur->_left;while (leftMax->_right != nullptr){parent = leftMax;leftMax = leftMax->_right;}swap(cur->_key, leftMax->_key);if (parent->_left == leftMax)parent->_left = leftMax->_left;elseparent->_right = leftMax->_left;cur = leftMax;}delete cur;return true;}}return false;
}

递归版本


          觉得不错的可以点赞+收藏+关注奥!!!谢谢大家的支持

http://www.xdnf.cn/news/4059.html

相关文章:

  • Linux内核视角:线程同步与互斥的原理、实现与锁优化策略
  • redis大全
  • 【Linux】进程地址空间
  • 【计网】ipconfig、ping、arp、tracert
  • 自定义一个 Spring Boot Starter -笔记
  • 移动应用开发:自定义 View 处理大量数据的性能与交互优化方案
  • Spring AI 与大语言模型工具调用机制详细笔记
  • react-13react中外部css引入以及style内联样式(动态className与动态style)
  • Android开发-工程结构
  • Linux云服务器配置git开发环境
  • day 13 不平衡数据集的处理
  • C++学习知识点汇总
  • git中android studio不想提交文件
  • 【能力比对】K8S数据平台VS数据平台
  • colcon: error: unrecognized arguments: --packages-select报错
  • GD32/STM32 ADC/DMA使用指南
  • QuecPython+腾讯云:快速连接腾讯云l0T平台
  • 巧记英语四级单词 Unit7-中【晓艳老师版】
  • 基于Jaccard算法的用户浏览历史推荐商品系统实战+springboot+vue源码实现
  • 【东枫科技】代理销售 NVIDIA DGX Spark 您的桌上有一台 Grace Blackwell AI 超级计算机。
  • [Survey]Remote Sensing Temporal Vision-Language Models: A Comprehensive Survey
  • C++【继承】
  • 1688平台商品详情接口开发指南(含Python代码示例)
  • 【东枫科技】代理英伟达产品:智能网卡
  • DTU_DTU厂家_5G/4G DTU终端_DTU模块_厦门计讯物联科技有限公司
  • 为什么Transformer推理需要做KV缓存
  • 2025年游戏行业DDoS攻防指南:智能防御体系构建与实战策略
  • 【C++】类和对象(一)
  • 【FreeRTOS-时间管理】
  • 0-1背包问题基础概念