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是二叉树的遍历操作,这里不再赘述。
<<提问分享>>
画一个红酒广告画一个金狮雕像
画一个法治社的宣传海报
从前,在一个遥远的国度里,有一条神奇的龙,它名叫青
一个姐姐,一个妹妹,一个弟弟,爸爸妈妈,和谐的在吃饭
画一个百年巨龟
街舞社海报 有中文的“街舞社”在中间 图中的人物是青春阳光的学生
阴雨连绵,富有山水诗意,烟雾缭绕的画
画一个小女孩晚上穿着白色连衣裙在大海边站在沙滩边踩水身边群星闪耀,要正面照
一只橘猫趴在开满花朵树上睡觉
一只坐在水池旁 桃花树下 看着水池中的鱼的猫
以消防安全为主题,创作一张插画,主体为消防车、起火的建筑颜色为红色、橙色、高对比度
青春阳光的街舞社海报
主体:一位手持宝剑头戴帷帽身着白衣的女侠客 环境:与世隔绝的深山老林 2D插画
省实民乐团画报
以消防安全为主题,创作一张插画
有山,有河流,还有一片竹林
阳光明媚的天气,阳光偏黄柔和,一只品种为金毛的小狗,在有花有草的森林里玩皮球
油画郁金香花海落日真实照片
街舞社海报 青春阳光 有“街舞社”在中间偏上
云山文学社海报 诗意 故事 文章
一个古老的佛像,以山为背景,佛像
谷歌小恐龙
真实照片油画玫瑰花
主题:街舞社海报
画一个戏剧社海报
绿色,古代,男子
青年女运动员在羽毛球馆打羽毛球,人物居中
画一个炸鸡在白色瓷碟,背景是大山中
主体:一座古老的寺庙 环境:山脉之中,旁边有瀑布流淌 行为:游客在参观,拍照 色彩:绿色和金色为主 构图:寺庙居中,瀑布和山脉作为背景 风格:写实
真实照片, 朦胧远山,柳树,雨水,2D插画
干白葡萄酒在自然大气的暗绿色背景里的广告
卖油翁背后的道理
http://chatgpt.jupyter.vip/pic/1173.jpg
画图:龙飞凤舞
讲一个关于龙的故事
画图:白云山
画图:水鱼
画图:鱼香茄子
mysql备份数据库如何指定端口
用python程序揭示位图和矢量图的区别
Ubuntu系统使用iptables开放指定端口
简单介绍PPT中插入超链接
简单介绍PPT中幻灯片的背景设置
简单介绍PPT中自定义动画
简单介绍幻灯片切换效果
用python获取PPT幻灯片数量,以及第二张幻灯片的标题及字体
Jupyter中用python程序显示图像文件
Windows平台host解析域名
用python开发一个考勤系统