[TOC]
## 定义
* 每个节点中的值必须大于(或等于)存储在其左子树中的任何值
* 每个节点中的值必须小于(或等于)存储在其右子树中的任何值
## 应用
#### [98\. 验证二叉搜索树](https://leetcode-cn.com/problems/validate-binary-search-tree/)
验证二叉搜索树
```cpp
class Solution {
public:
bool isValidBST(TreeNode* root) {
TreeNode* prev = NULL;
return helper(root, prev);
}
bool helper(TreeNode* root, TreeNode*& prev)
{
if (root == NULL)
return true;
if (!helper(root->left, prev))
return false;
if (prev && prev->val >= root->val)
return false;
prev = root;
return helper(root->right, prev);
}
};
```
#### [701\. 二叉搜索树中的插入操作](https://leetcode-cn.com/problems/insert-into-a-binary-search-tree/)
给定二叉搜索树(BST)的根节点和要插入树中的值,将值插入二叉搜索树。 返回插入后二叉搜索树的根节点。 保证原始二叉搜索树中不存在新值。
注意,可能存在多种有效的插入方式,只要树在插入后仍保持为二叉搜索树即可。 你可以返回任意有效的结果。
```cpp
class Solution {
public:
TreeNode* insertIntoBST(TreeNode* root, int val) {
if (root == NULL)
return new TreeNode(val);
if (val < root->val)
root->left = insertIntoBST(root->left, val);
else
root->right = insertIntoBST(root->right, val);
return root;
}
};
```
#### [450\. 删除二叉搜索树中的节点](https://leetcode-cn.com/problems/delete-node-in-a-bst/)
给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。
一般来说,删除节点可分为两个步骤:
1. 首先找到需要删除的节点;
2. 如果找到了,删除它。
```
class Solution {
public:
TreeNode* deleteNode(TreeNode* root, int key) {
if (root == NULL)
return root;
if (key < root->val)
root->left = deleteNode(root->left, key);
else if (key > root->val)
root->right = deleteNode(root->right, key);
else
{
TreeNode* del = root;
if (root->left == NULL)
root = root->right;
else if (root->right == NULL)
root = root->left;
else
{
TreeNode* successor = new TreeNode(minimum(root->right)->val);
root->right = deleteNode(root->right, successor->val);
successor->left = root->left;
successor->right = root->right;
root = successor;
}
delete del;
}
return root;
}
TreeNode* minimum(TreeNode* root)
{
while (root->left)
root = root->left;
return root;
}
};
```
#### [110\. 平衡二叉树](https://leetcode-cn.com/problems/balanced-binary-tree/)
给定一个二叉树,判断它是否是高度平衡的二叉树。
本题中,一棵高度平衡二叉树定义为:
一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过1。
```
class Solution {
public:
bool isBalanced(TreeNode* root) {
if (root == NULL)
return true;
if (abs(height(root->left) - height(root->right)) > 1)
return false;
return isBalanced(root->left) && isBalanced(root->right);
}
int height(TreeNode* root)
{
if (root == NULL)
return 0;
int leftHeight = height(root->left);
int rightHeight = height(root->right);
return (leftHeight > rightHeight ? leftHeight : rightHeight) + 1;
}
};
```
#### [剑指 Offer 68 - I. 二叉搜索树的最近公共祖先](https://leetcode-cn.com/problems/er-cha-sou-suo-shu-de-zui-jin-gong-gong-zu-xian-lcof/)
给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。
```cpp
class Solution {
public:
TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
if (root == NULL)
return root;
if (min(p->val, q->val) <= root->val && max(p->val, q->val) >= root->val)
return root;
if (min(p->val, q->val) > root->val)
return lowestCommonAncestor(root->right, p, q);
return lowestCommonAncestor(root->left, p, q);
}
};
```
### [剑指 Offer 33. 二叉搜索树的后序遍历序列](https://leetcode-cn.com/leetbook/read/illustration-of-algorithm/5vwxx5/)
输入一个整数数组,判断该数组是不是某二叉搜索树的后序遍历结果。如果是则返回 `true`,否则返回 `false`。假设输入的数组的任意两个数字都互不相同。
```cpp
class Solution {
public:
bool verifyPostorder(vector<int>& postorder) {
return helper(postorder, 0, postorder.size() - 1);
}
bool helper(vector<int>& postorder, int i, int j) {
if (i >= j) return true;
int k = i;
while (postorder[k] < postorder[j])
k++;
int m = k;
while (postorder[k] > postorder[j])
k++;
return k == j && helper(postorder, i, m - 1) && helper(postorder, m, j - 1);
}
};
```
- 空白目录
- 算法
- 排序
- 冒泡排序
- 选择排序
- 插入排序
- 归并排序
- 快速排序
- 计数排序
- 桶排序
- 基数排序
- 希尔排序
- 堆排序
- 二分查找
- 最小堆
- 最小索引堆
- 平衡二叉树(AVL tree)
- bitmap位图
- 布隆过滤器
- hashmap
- topK
- 跳表
- LRU Cache
- kmp
- 最小堆和堆排序
- 最短路径
- C++
- 运行时类型判断RTTI
- C++反射
- 手动实现智能指针
- 序列化实现
- rpc实现
- std::forward
- 函数指针的妙用
- C/C++
- std::function
- 同步队列
- 线程池实现
- std::promise
- 深入理解虚函数
- extern "C" 关键字讲解
- 大端小端的区别
- 简历
- 简历1
- redis
- 数据结构和对象
- sds
- list
- zskiplist
- 腾讯云redis面试题总结
- redis集群部署
- LeetCode
- 目标
- go基础
- 算法快速入门
- 数据结构篇
- 二叉树
- 链表
- 栈和队列
- 二进制
- 基础算法篇
- 二分搜索
- 排序算法
- 动态规划
- 算法思维
- 递归思维
- 滑动窗口思想
- 二叉搜索树
- 回溯法
- 其他
- 剑指offer
- 笔记
- git代理加速
- Linux
- vim大法
- vscode远程不能跳转
- cmake
- 设计模式
- 单例模式
- 简单工厂模式
- 外观模式
- 适配器模式
- 工厂方法模式
- 抽象工厂模式
- 生成器模式
- 原型模式
- 中介者模式
- 观察者模式
- 访问者模式
- 命令模式
- 网络编程
- epoll reactor模式
- linux timerfd系列函数总结
- IO
- mapreduce
- 反射器
- leo通信库
- Mutex
- Condition
- thread
- raft
- 协程
- hook
- 定时器
- 别人的面试经验
- 面试题
- vector崩溃问题
- JAVA
- Linux java环境配置
- ucore
- lab1
- FreeNOS
- leveldb
- 刷题笔记
- 回文串
- 前缀树
- 字符串查找
- 查找两个字符串a,b中的最长公共子串
- 动态规划
- golang
- 顺序循环打印实现
- 数据结构
- rpc运用
- python
- 单例
- 深拷贝浅拷贝
- 链表
- python基础题
- mysql
- 事务
- Linux
- 共享内存
- 刷题记录
- 贪心算法
- 动态规划
- 面试
- 腾讯C++面试
- 微众面试JD
- 迅雷网络面试
- 学习网址
- rabbitMq
