力扣二叉树--第三十六天

前言

两天没写题了,期末月,压力有点大,休息一下,释放一下压力。焦虑常在,调整好心态啊!度过这一个月。写中序遍历的时候,发现自己竟然对树是怎么遍历的很模糊!!!前面那么多天怎么过来的!现在弄懂它,参考文章二叉树遍历的递归实现详解(先序、中序、后序和层次遍历)

内容

一、验证二叉搜索树

98. 验证二叉搜索树

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

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

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

陷阱:

不能单纯的比较左节点小于中间节点,右节点大于中间节点

我们要比较的是 左子树所有节点小于中间节点,右子树所有节点大于中间节点

Go 复制代码
func isValidBST(root *TreeNode)bool{
   return check(root,math.MinInt64,math.MaxInt64)
}
func check(root *TreeNode,min,max int)bool{
   if root==nil{
       return true
   }
   if root.Val>=max||root.Val<=min{
       return false
   }//检查当前节点的值是否在给定的最小值和最大值之间。如果不在,则返回 false,因为这表示当前树不是二叉搜索树。
   return check(root.Left,min,root.Val)&&check(root.Right,root.Val,max) //对于左子树,最小值保持不变,最大值变为当前节点的值,以确保左子树中的所有值都小于当前节点的值。对于右子树,最小值变为当前节点的值,最大值保持不变,以确保右子树中的所有值都大于当前节点的值。
}
中序遍历

中序遍历下,输出的二叉搜索树节点的数值是有序序列。

有了这个特性,验证二叉搜索树,就相当于变成了判断一个序列是不是递增的了。

Go 复制代码
func isValidBST(root *TreeNode)bool{
   res:= inorder(root)//res:= inorder(root) 调用 inorder 函数获取二叉树的中序遍历结果,并将其赋值给 res。
  for i:=0;i<len(res)-1;i++{
      if res[i]>=res[i+1]{
        return false
      }
        
  }

   return true 
}

  func inorder(node *TreeNode)[]int{
      
      if node==nil{
          return []int{}
      }
       res := inorder(node.Left)
    res = append(res, node.Val)
    res = append(res, inorder(node.Right)...)
    return res

  }

最后

今天就到这吧,不要再晚上八九点开始学习了,利用好白天的时间。

相关推荐
一分之二~3 分钟前
回溯算法--递增子序列
开发语言·数据结构·算法·leetcode
m0_639397295 分钟前
代码随想录算法训练营第五十天|图论理论基础,深搜理论基础,98. 所有可达路径,广搜理论基础
算法·图论
智驱力人工智能11 分钟前
无人机车辆密度检测系统价格 询价准备 需要明确哪些参数 物流园区无人机车辆调度系统 无人机多模态车流密度检测技术
深度学习·算法·安全·yolo·无人机·边缘计算
福尔摩斯张12 分钟前
【实战】C/C++ 实现 PC 热点(手动开启)+ 手机 UDP 自动发现 + TCP 通信全流程(超详细)
linux·c语言·c++·tcp/ip·算法·智能手机·udp
罗湖老棍子12 分钟前
【例3-3】医院设置(信息学奥赛一本通- P1338)
数据结构·c++·算法·
不想写笔记14 分钟前
算法 C语言 冒泡排序
c语言·笔记·算法·排序算法
qq 87622396515 分钟前
基于灰色预测模型的预测算法研究:探讨不确定性与数学建模的交融
golang
苏琢玉16 分钟前
用 Go 像写 Web 一样做桌面应用:完全离线的手机号归属地查询工具
vue.js·golang
xu_yule20 分钟前
算法基础-路径类dp
算法
智驱力人工智能22 分钟前
从项目管理视角 拆解景区无人机人群密度分析系统的构建逻辑 无人机人员密度检测 无人机人群密度检测系统价格 低空人群密度统计AI优化方案
人工智能·深度学习·算法·安全·无人机·边缘计算