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是二叉树的遍历操作,这里不再赘述。
<<提问分享>>
pyttsx3合成语言到文件pyttsx3安装、入门、进阶示例
逆元在信息学竞赛中的应用
ubuntu20.04安装英伟达显卡驱动
生活中能用数组解决的实例详解
与二维数组相关的基础算法实例
与一维数组相关的基础算法解析
轻量级markdown渲染前端框架及其使用方法
python将base64转jpg文件
python将base64转图像
RTX3060Ti显卡详细参数
RTX3060显卡详细参数
RTX2080Ti显卡详细参数
MySQL备份所有数据库的命令
mysql备份恢复数据库命令总结
如何提高打字速度?
python执行命令,并限制时间和内存
python获取excel表中C13单元格的各个属性
python读取excel中成绩工作表的第3行第四列单元格
python读取excel表格信息示例
读伤仲永有感,500字
Linux系统用户登录验证方式可以用MySQL吗?如何配置?
ubuntu重装系统,用户密码等信息如何备份与恢复
Ubuntu16.04安装VNC桌面环境和火狐浏览器
用ps命令输出指定用户的详细进程
用linux命令统计每个用户内存使用量
Ubuntu配置3389远程桌面连接本地用户登录
Ubuntu配置3389远程桌面连接
Linux常用命令及其用法讲解
MySQL常用字符串函数及其用法
生成对抗网络入门讲解与应用举例
file_get_contents带cookies发送https请求
nginx配置ssl证书
举个简单的例子,告诉我什么是期望
二叉排序树的原理讲解及其C++代码
nginx通过url重写实现伪静态示例
php用正则表达式匹配所有5位数
php用正则表达式替换行头空格
C++中multimap怎么用?
DevC++配置C++11、C++14编译环境
固态硬盘中的QLC、MLC、TLC
Linux系统中怎么修改密码
python程序设计顺序结构的有趣例子
使用python写一个小学生能实现的游戏
使用python进行人脸识别的原理及简单代码实现
使用python进行文本分类的原理及简单代码实现
详细介绍OpenAI中的CLIP,最好有代码
OpenAI所有接口介绍
OpenAI各种接口介绍及其用法
参加信息学竞赛,从小学几年级开始学比较合适?