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

LeetCode第98题 - 有效的括号

题目

解答

方案一

class Solution {public boolean isValidBST(TreeNode root) {if (root == null) {return true;}if (root.left == null && root.right == null) {return true;}if (root.left != null && root.left.val >= root.val) {return false;}if (root.right != null && root.right.val <= root.val) {return false;}return isValidBST(root.left) && isValidBST(root.right);}
}

方案二

class Solution {public boolean isValidBST(TreeNode root) {return validate(root, Long.MIN_VALUE, Long.MAX_VALUE);}public boolean validate(TreeNode node, long min, long max) {if (node == null) {return true;}if (node.val <= min || node.val >= max) {return false;}return  validate(node.left, min, node.val) && validate(node.right, node.val, max);}
}

要点
二叉搜索树中的任意节点,均满足如下条件:

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

粗看上去,方案一似乎可以满足要求,但实际上并不是,方案一没有完整验证1和2两个条件。
另外从代码量的规模看,方案二用较少的代码量,完成了更多的特性,更加优雅。

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

相关文章:

  • Nacos学习思维导图
  • 新视野英语课本复盘1
  • Sentinel整合OpenFeign
  • PyTorch实战:基于Seq2seq模型处理机器翻译任务(模型预测)
  • stm32学习总结:5、Proteus8+STM32CubeMX+MDK仿真串口并使用串口打印日志(注意重定向printf到串口打印的问题)
  • SAFe大规模敏捷企业级实训
  • 中医电子处方系统,西医个体诊所门诊卫生室病历记录查询软件教程
  • 搞定ESD(八):静电放电之原理图设计
  • 微前端 Micro App
  • Java amr格式转mp3格式
  • Vue2面试题:说一下虚拟DOM的原理?
  • Spring对bean的管理
  • Character Controller Smooth
  • 企业内训系统源码开发实战:搭建实践与经验分享
  • 15.三数之和(双指针,C解答附详细分析)
  • SpringCloud微服务 【实用篇】| Dockerfile自定义镜像、DockerCompose
  • Vue3+TS+ElementPlus的安装和使用教程【详细讲解】
  • 浅析锂电池保护板(BMS)系统设计思路(四)SOC算法-扩展Kalman滤波算法
  • 构建异步高并发服务器:Netty与Spring Boot的完美结合
  • uniapp实现文字超出宽度自动滚动(在宽度范围之内不滚动、是否自动滚动、点击滚动暂停)
  • win11 电脑睡眠功能失效了如何修复 win11 禁止鼠标唤醒
  • 内坐标转换计算
  • vue中 components自动注册,不需要一个个引入注册方法
  • web自动化测试从入门到持续集成
  • python小工具之弱密码检测工具
  • 链接器--动态链接器--延迟绑定与动态链接器是什么?学习笔记二
  • JMeter CSV 参数文件的使用方法
  • how2heap-2.23-06-unsorted_bin_into_stack
  • (学习打卡2)重学Java设计模式之六大设计原则
  • 数据结构:第7章:查找(复习)