Leetcode 98 验证二叉搜索树 C++实现

Leetcode 98. 验证二叉搜索树

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

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

  • 节点的左子树只包含小于当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。
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) {}
 * };
 */

**算法:**结点的左子树必定全部小于该结点值 val ,结点的右子树必定全部大雨该结点值 val ,所以创立新函数导入 maxmin 值,再令其满足其他条件即可。

注意,不能单独判断该结点的左孩子结点是否小于他,右孩子结点是否大于他,必须要求整个子树都符合条件才可。

代码:

cpp 复制代码
class Solution {
public:
    bool BST(struct TreeNode* node,long min,long max){
        if(!node) return true;// 空结点返回true
        if(node->val <= min || node->val >= max)    return false;// 结点值val如果小于最小的或者大于最大的,返回false
        return BST(node->left,min,node->val) && BST(node->right,node->val,max);
    }
    bool isValidBST(TreeNode* root) {
        return BST(root,LONG_MIN,LONG_MAX);// LONG_MIN是long的最小数值,LONG_MAX是long的最大数值
    }
};
相关推荐
LXS_3575 小时前
Day 18 C++提高 之 STL常用容器(string、vector、deque)
开发语言·c++·笔记·学习方法·改行学it
源代码•宸5 小时前
Leetcode—620. 有趣的电影&&Q3. 有趣的电影【简单】
数据库·后端·mysql·算法·leetcode·职场和发展
2301_800256116 小时前
地理空间数据库中的CPU 和 I/O 开销
数据库·算法·oracle
deng-c-f6 小时前
Linux C/C++ 学习日记(53):原子操作(二):实现shared_ptr
开发语言·c++·学习
一个不知名程序员www6 小时前
算法学习入门---结构体和类(C++)
c++·算法
墨雪不会编程7 小时前
C++ string 详解:STL 字符串容器的使用技巧
java·开发语言·c++
yangpipi-8 小时前
《C++并发编程实战》第5章 C++内存模型和原子操作
android·java·c++
SunkingYang8 小时前
MFC进程间消息通信深度解析:SendMessage、PostMessage与SendNotifyMessage的底层实现与实战指南
c++·mfc·共享内存·通信·postmessage·sendmessage·进程间
阿亮爱学代码8 小时前
Java 面试 (三)
面试·职场和发展