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的最大数值
    }
};
相关推荐
蓝速科技4 分钟前
3D 数字人全息舱算力部署方案对比:本地 X86 独显架构与云端 RK 架构怎么选才好
数据结构·人工智能·算法·架构·排序算法
fpcc11 分钟前
C++编程实践——提高缓存的命中
c++·缓存
小张成长计划..18 分钟前
【C++】37:IO库(扩展)
c++
qingyulee18 分钟前
集成学习、聚类算法
算法·聚类·集成学习
Cx330❀19 分钟前
【Qt 核心机制篇】深度解析 Qt 信号与槽(Signals & Slots)机制:从底层原理、实战演练到 Lambda 进阶
linux·开发语言·c++·人工智能·qt·ubuntu
学习,学习,在学习19 分钟前
Modbus TCP同步通信方式实现异步级效率
网络·c++·qt·网络协议·tcp/ip·qt5
lqqjuly21 分钟前
机器人状态估计与 SLAM—概率推理到 simultaneous Localization and Mapping
算法·机器人
清 澜21 分钟前
基于 LangChain 从零搭建知识库问答系统
人工智能·职场和发展·大模型·agent·知识库
Cx330❀23 分钟前
【Linux网络】从零构建高性能UDP服务器:从Echo到英译汉业务级实现
大数据·linux·服务器·开发语言·网络·c++·udp
sali-tec24 分钟前
C# 基于OpenCv的视觉工作流-章79-单位转换
图像处理·人工智能·opencv·算法·计算机视觉