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 _right; } //找到删除元素了 else { //左子树为空 if (cur->_left == nullptr) { //要删除的数据是根节点 if (cur == _root) _root = _root->_right; else { if (parent->_right == cur) parent->_right = cur->_right; else parent->_left = cur->_right; } } //右子树为空 else if (cur->_right == nullptr) { //要删除的数据是根节点 if (cur == _root) { _root = _root->_left; } else { if (parent->_right == cur) parent->_right = cur->_left; else parent->_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; else parent->_right = leftMax->_left; cur = leftMax; } delete cur; return true; } } return false; }
递归版本
觉得不错的可以点赞+收藏+关注奥!!!谢谢大家的支持
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们。