leetcode做题笔记98. 验证二叉搜索树

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

  • 节点的左子树只包含小于当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

思路一:递归

cpp 复制代码
void inOrder(struct TreeNode* root,int arr[],int *len){
    if(root != NULL){
        inOrder(root->left,arr,len);
        arr[(*len)++]=root->val;
        
        inOrder(root->right,arr,len);
    }
}
bool isValidBST(struct TreeNode* root){
    int arr[10000];
    int len=0;
    inOrder(root,arr,&len);
    for(int i=0;i<len-1;i++){
        if(arr[i]>=arr[i+1]){
            return false;
        }
    }
    return true;
}

分析:

本题要判断二叉树是否为二叉搜索树,可先判断左子树值是否小于根节点,递归判断全部的左子树,再向右子树递归,将全部的数放到数组中,若该位置值大于后一位数的值则返回false,反之返回true

总结:

本题考察二叉树的相关应用,对二叉搜索树定义理解后使用递归将每个数值记录再判断即可得到答案。

相关推荐
亦复何言??几秒前
BeyondMimic 论文解析
人工智能·算法·机器人
WolfGang0073215 分钟前
代码随想录算法训练营 Day20 | 回溯算法 part02
算法
YXXY3137 分钟前
前缀和算法
算法
客卿1237 分钟前
滑动窗口--模板
java·算法
_日拱一卒25 分钟前
LeetCode:滑动窗口的最大值
数据结构·算法·leetcode
codeの诱惑36 分钟前
推荐算法(一):数学基础回顾——勾股定理与欧氏距离
算法·机器学习·推荐算法
落樱弥城36 分钟前
Vulkan Compute 详解
算法·ai·图形学
Book思议-37 分钟前
【数据结构】字符串模式匹配:暴力算法与 KMP 算法实现与解析
数据结构·算法·kmp算法·bf算法
丝斯20111 小时前
AI学习笔记整理(79)——Python学习8
人工智能·笔记·学习
客卿1231 小时前
动态规划--模板--完全背包
算法·动态规划