ChatGPT体验 AI绘画体验
二叉排序树的原理讲解及其C++代码
提问人:ppw_crxis 时间:2023-04-22 公开状态:

提问人:ppw_crxis 时间:2023-04-22 公开状态:


二叉排序树是一种特殊的二叉树,满足以下条件:
1. 对于每个节点,左子树上的所有节点的值都小于它的值,右子树上的所有节点的值都大于它的值;
2. 左右子树都是二叉排序树。
因此,二叉排序树的节点的值可以是任意的可比较类型,比如整数、浮点数、字符串等。
二叉排序树的搜索操作是非常高效的,搜索一个节点的时间复杂度与树的高度有关,最坏情况下是O(n),但是平均情况下可以达到O(logn)。
下面给出二叉排序树的C++实现:
```
#include<iostream>
using namespace std;
struct TreeNode {
int val;
TreeNode* left;
TreeNode* right;
TreeNode(int x) : val(x), left(NULL), right(NULL) {}
};
class BST {
public:
BST() : root(NULL) {}
bool search(int val) {
TreeNode* cur = root;
while (cur) {
if (cur->val == val) {
return true;
} else if (cur->val > val) {
cur = cur->left;
} else {
cur = cur->right;
}
}
return false;
}
void insert(int val) {
if (!root) {
root = new TreeNode(val);
return;
}
TreeNode* cur = root;
while (cur) {
if (cur->val > val) {
if (!cur->left) {
cur->left = new TreeNode(val);
break;
}
cur = cur->left;
} else {
if (!cur->right) {
cur->right = new TreeNode(val);
break;
}
cur = cur->right;
}
}
}
void remove(int val) {
root = removeHelper(root, val);
}
private:
TreeNode* root;
TreeNode* removeHelper(TreeNode* node, int val) {
if (!node) {
return NULL;
}
if (node->val > val) {
node->left = removeHelper(node->left, val);
} else if (node->val < val) {
node->right = removeHelper(node->right, val);
} else {
if (!node->left) {
TreeNode* rightNode = node->right;
delete node;
return rightNode;
}
if (!node->right) {
TreeNode* leftNode = node->left;
delete node;
return leftNode;
}
TreeNode* p = node->right;
while (p->left) {
p = p->left;
}
node->val = p->val;
node->right = removeHelper(node->right, p->val);
}
return node;
}
};
int main() {
BST bst;
bst.insert(8);
bst.insert(3);
bst.insert(6);
bst.insert(10);
bst.insert(1);
bst.insert(14);
cout << "Tree traversal: " << endl;
cout << "In-order: ";
inorderTraversal(bst.root);
cout << endl;
cout << "Pre-order: ";
preorderTraversal(bst.root);
cout << endl;
cout << "Post-order: ";
postorderTraversal(bst.root);
cout << endl;
bst.remove(3);
cout << "Tree after removing 3: " << endl;
inorderTraversal(bst.root);
cout << endl;
return 0;
}
```
注:inorderTraversal、preorderTraversal、postorderTraversal是二叉树的遍历操作,这里不再赘述。
<<提问分享>>
bitset用法示例及优化背包详解详细介绍C++程序设计中的线性基
信息学竞赛中卡特兰数的典型应用
C++中的unique对一位数组进行去重
海龟库种还有那些图标,除了海龟之外
给出代码:用海龟库画100个大小颜色随机的圆,使用rgb颜色、python3.65
使用海龟库绘制五角星,给出代码就行
用flowchart语法绘制“求圆的面积”的流程图
python程序设计中,print语句能做哪些使用的小工具?
用mermaid语法绘制“求圆的面积”的流程图
流程图中,为什么要用不同的图形表示输入输出、处理过程、条件判断?
自然语言、伪代码、流程图描述算法的异同
机器语言、汇编语言、高级语言科普
图画围绕诗句“一蓑烟雨任平生”画一份水墨画
白云山旁的省实
画一只威武霸气的猫
海报,化学,要体现化学的强大
c++map能开二维数组吗
七下历史思维导图
写一篇题目是灯的1000字亲情作文
用mermaid语法绘制初一数学全部知识点的思维导图,要求左右方向、细化到十层,要有上下学期的分类
用mermaid语法绘制初一数学全部知识点的思维导图,要求左右方向、细化到十层,要有具体例子,要美化整体
介绍说明“明日方舟”中“德克萨斯”的故事和背景和爱好和朋友和性格
校园里的凤凰树 积极向上 写一篇文章1000字
校园里的凤凰树 积极向上
画出现在的城市
画一个关于Flash使用的思维导图
写一篇作文------校园里的紫薇 800字以上 要求:有升华,描写出紫薇的样子
求证:任何大于2的偶数都可以表示为两个素数之和
用mermaid语法绘制初一数学全部知识点的思维导图,要求左右方向、细化到十层
用mermaid语法绘制广州市初中信息技术Excel常见操作题考点思维导图(左右方向)
用mermaid语法绘制初一数学全部知识点的思维导图,要求左右方向、细化到四五层
用mermaid语法绘制初一数学全部知识点的思维导图(左右方向)
用mermaid语法绘制初一数学上学期全部知识点的思维导图
如何练习篮球基本功
如何快速提升篮球水平
青草膏精美广告
画个金色宇宙,有一只绿色的猫在椅子上跳舞
C++深度优先搜索模板
画一幅动漫男高中生打排球的动漫风格的画
画一条颜色丰富的烤鱼
画一个鸡公福
用C++写一个五子棋,要求有判断胜负、和棋、自定义棋盘大小
python语言中的{}是怎么用的
bool语言
你怎么看待人工智能
用C++写一个扫雷游戏
c++二维字符数组怎么输入字符串
实现文化自信的途径
C++ set怎么用,有哪些常用的方法