leetcode 98 验证二叉搜索树

一、题目描述

二、解题思路

整体思路

二叉搜索树的中序遍历序列是单调递增的,我们可以根据这个原则来判断当前的二叉树是否为二叉搜索树。由于要借助中序遍历的方法,所以我们借助递归来解决这个问题。

具体思路

考虑到空间的开销,我们无需申请数组来寄存中序遍历的序列,可以设置一个全局变量pre,来记录前一个数值,辅助判断。

**(1)函数功能:**isValidBST函数用于判断以root为根节点的二叉树是否为二叉搜索树;

**(2)递归出口:**当root为空节点时,直接返回true

(3)函数体:

**<1>处理左子树,判断左子树是否为二叉搜索树。**当左子树不为二叉搜索树,直接返回false,进行左剪枝;

**<2>处理当前节点。**判断当前节点的值是否大于pre,更新pre的值;

**<3>处理右子树,判断右子树是否为二叉搜索树。**当右子树不为二叉搜索树,直接返回false,进行右剪枝。

**(4)**返回left&&cur&&right即可。

三、代码实现

cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
    long pre=LONG_MIN;
public:
    bool isValidBST(TreeNode* root) {
       //边界处理
       if(root==nullptr) return true;
       //处理左子树
       bool left=isValidBST(root->left);
       if(left==false) return false;//左剪枝
       //处理本身
       bool cur=true;
       if(root->val<=pre) cur=false;
       pre=root->val;
        //处理右子树
        bool right=isValidBST(root->right);
        if(right==false) return false;//右剪枝

        return left&&cur&&right;
    }
};
相关推荐
Once_day12 分钟前
C++之《程序员自我修养》读书总结(1)
c语言·开发语言·c++·程序员自我修养
Trouvaille ~21 分钟前
【Linux】TCP Socket编程实战(一):API详解与单连接Echo Server
linux·运维·服务器·网络·c++·tcp/ip·socket
偷吃的耗子27 分钟前
【CNN算法理解】:CNN平移不变性详解:数学原理与实例
人工智能·算法·cnn
坚果派·白晓明33 分钟前
在鸿蒙设备上快速验证由lycium工具快速交叉编译的C/C++三方库
c语言·c++·harmonyos·鸿蒙·编程语言·openharmony·三方库
小镇敲码人40 分钟前
深入剖析华为CANN框架下的Ops-CV仓库:从入门到实战指南
c++·python·华为·cann
dazzle1 小时前
机器学习算法原理与实践-入门(三):使用数学方法实现KNN
人工智能·算法·机器学习
那个村的李富贵1 小时前
智能炼金术:CANN加速的新材料AI设计系统
人工智能·算法·aigc·cann
张张努力变强2 小时前
C++ STL string 类:常用接口 + auto + 范围 for全攻略,字符串操作效率拉满
开发语言·数据结构·c++·算法·stl
万岳科技系统开发2 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
小镇敲码人2 小时前
探索CANN框架中TBE仓库:张量加速引擎的优化之道
c++·华为·acl·cann·ops-nn