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是二叉树的遍历操作,这里不再赘述。
<<提问分享>>
画图:层云叠嶂的青山,一排接着一排,云朵很多朦胧,遮住了青山,写实风sqlite数据库数据类型整理
php5对sqlite进行增删查改操作
天上打着雷,一位神女踏空而行剑指天空
怎样掌握学习的方法
古人隐居深林
画图:山边的学校,写实,黄灰色山水书院风格
幽静的树林,淙淙的小溪,有一只狐狸在溪边喝水,很惬意
画李白在竹林舞剑
画图:画一个校园后面有座山,现代校园
C++状态压缩枚举子集详细介绍
海报,物理,要体现物理的强大
广式早茶
画一个初中生正在操场上调试固定翼航模,多一些科技气息
山脉之中有雨青蓝色
画图:科技部宣传海报
写一篇作文——雨水800字以上 要求:有叶子,雨滴,水
斑马在奔跑
海报社招生海报/艺术感
图画围绕诗句“萧瑟萧瑟敬春风”画一份水墨画
物理社海报,要求有理科感
画图:做一个“物理社团“的海报,要有适当的文字介绍,地点要在实验室内,要新颖
可爱的小孩在花园里
画一幅充满科技感的,电子竞技社的海报。要求使用景深,中心构图,地点在室外
法制社团宣传海报,几十个人学法官用力敲锤子,在高大的法庭中,
给 法治社 设计一幅海报
画云山诗会,古风,汉服,闲敲棋子落灯花,手稿画风,儒雅清亮
给 蒹葭 这首诗配一幅图
一个戴眼镜的女生在电脑前写作业
给《最美诗经》这本书配一幅图
云山海报社招生海报/简约
画一个正在做数学题冥思苦想的学生,戴眼镜
画一个会飞的老奶奶
一头牛在天空飞翔
早晨海上日出图画
画一名手握长剑的剑客站在高山之巅
乌鸦喝水
画图:枯藤老树昏鸦
非常可爱的毛绒绒的 小小的白色的猫
李白在竹林喝酒
画一个精致的凤凰山
远景,日出与山脉相接
阳光明媚的西方小城镇
画一桌子香喷喷的美食
画图:凤鸣九天 主体:火凤凰 环境:梧桐树林上方
夕阳下,两个少女坐在地下看夕阳(只能看见背影)
画一个飞在夕阳天空中的红色独角鲸
核废水有办法制止吗
画一个开心逛街的女人,手里抱着可爱的猫猫,喝着奶茶
画一个长得很好看的女孩,大眼睛,短头发,学习很好,中国女孩