当前位置: 首页 > news >正文

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

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

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

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

思路一:递归

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

总结:

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

http://www.lryc.cn/news/140001.html

相关文章:

  • C# 中Lambda中的的匿名函数
  • 铰接式车辆的横向动力学仿真提供车辆模型研究(Matlab代码实现)
  • Ubuntu20 安装 libreoffice
  • HTTP协议(JavaEE初阶系列15)
  • 机器学习基础10-审查回归算法(基于波士顿房价的数据集)
  • 基于 CentOS 7 构建 LVS-DR 群集。配置nginx负载均衡。
  • 【云原生】Docker的数据管理(数据卷、容器互联)
  • 使用vlc在线播放rtsp视频url
  • copy is all you need前向绘图 和疑惑标记
  • 【附安装包】Vred2023安装教程
  • ASP.NET Core 中的 Dependency injection
  • 优化物料编码规则,提升物料管理效率
  • Jetbrains IDE新UI设置前进/后退导航键
  • 借助frp的xtcp+danted代理打通两边局域网p2p方式访问
  • 2023年高教社杯数学建模思路 - 案例:FPTree-频繁模式树算法
  • 批量根据excel数据绘制饼状图
  • C++头文件和std命名空间
  • 浏览器有哪几种缓存?各种缓存之间的优先级
  • 【C++】list
  • 剪枝基础与实战(2): L1和L2正则化及BatchNormalization讲解
  • C语言学习笔记---指针进阶01
  • 【Go 基础篇】Go 语言字符串函数详解:处理字符串进阶
  • GAN原理 代码解读
  • HTML的label标签有什么用?
  • docker在阿里云上的镜像仓库管理
  • html-dom核心内容--四要素
  • golang的继承
  • Google Play商店优化排名因素之应用截图与视频
  • fastadmin iis伪静态应用入口文件index.php
  • 0821|C++day1 初步认识C++