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

济南专业做网站公司哪家好郑州网络推广专业公司

济南专业做网站公司哪家好,郑州网络推广专业公司,网站建设实施计划,net framework可以用来做网站吗给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义如下: 节点的左子树只包含 小于 当前节点的数。节点的右子树只包含 大于 当前节点的数。所有左子树和右子树自身必须也是二叉搜索树。 示例 1: 输入&…

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

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

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

示例 1:

输入:root = [2,1,3]

输出:true

示例 2:

输入:root = [5,1,4,null,null,3,6]

输出:false

解释:根节点的值是 5 ,但是右子节点的值是 4 。提示:

  • 树中节点数目范围在[1, 104] 内
  • -231 <= Node.val <= 231 - 1

思路:

初始化
  • 创建一个栈,用于存储尚未处理的节点。

  • 设置一个变量 lastTreeNode,用于记录上一个访问的节点的值。初始值为 long.MinValue,确保第一个节点的值总是大于它。

  • 设置一个指针 current,初始指向根节点 root

主循环

循环条件是:current 不为 null 或者栈不为空。这意味着还有节点需要处理。

  1. 将所有左子节点压入栈

    • 从当前节点 current 开始,沿着左子树一直向下,将所有左子节点依次压入栈中。

    • 每次将当前节点压入栈后,将 current 指向它的左子节点。

    • 这一步确保了左子树的所有节点都被处理。

  2. 弹出栈顶节点并访问

    • 当左子树的所有节点都被压入栈后,弹出栈顶节点。此时,栈顶节点是当前需要访问的节点。

    • 将弹出的节点赋值给 current

  3. 检查当前节点值是否满足BST性质

    • 比较当前节点的值 current.val 和上一个访问的节点值 lastTreeNode

    • 如果当前节点的值小于或等于 lastTreeNode,说明这棵树不是有效的BST,直接返回 false

  4. 更新上一个访问的节点值

    • 将当前节点的值赋值给 lastTreeNode,以便在下一次循环中使用。

  5. 转向右子树

    • current 指向当前节点的右子节点。

    • 如果当前节点没有右子节点,current 会变成 null,循环会继续从栈中弹出下一个节点(即当前节点的祖先节点的右子树)。

循环结束
  • currentnull 且栈为空时,说明所有节点都已处理完毕。

  • 如果在整个遍历过程中没有发现任何违反BST性质的情况,返回 true,表示这棵树是有效的BST。

代码:C#

public class Solution {

    public bool IsValidBST(TreeNode root) {

        if(root==null)

        return true;

    Stack<TreeNode> stack=new Stack<TreeNode>();

    TreeNode current=root;

    long lastTreeNode=long.MinValue;

    while(current!=null ||stack.Count>0)

    {

        //将所有左子节点存入这个栈中,而且最低下是根节点

        while(current!=null)

        {

            stack.Push(current);

            current=current.left;

        }

         //弹出栈的一个节点

         current=stack.Pop();

         //判断当前节点是否小于上一个节点,第一次进入的时候是跟最小值比,第一个节点值随便多大

         if(current.val<=lastTreeNode)

         {

            return false;

         }

         //记下当前节点的值

         lastTreeNode=current.val;

         //将当前节点转为右子树届节点

         current=current.right;

    }

    return true;

    }

}

http://www.dtcms.com/wzjs/175853.html

相关文章:

  • 哪里创建免费的网站百度搜索网站优化
  • 做分析图的地图网站百度网站的优化方案
  • 怎么做微信推送 网站免费seo网站诊断
  • 联通公司做网站吗拼多多关键词排名查询软件
  • 哪个网站做动图品牌推广软文案例
  • 万网的怎么做网站地图百度极速版推广
  • 太原网站建设联系方式windows优化大师收费吗
  • 今日头条收录网站入口网络营销师培训费用是多少
  • 什么做网站赚钱优化游戏性能的软件
  • 网站怎么做才能上百度首页杭州排名优化软件
  • 网站建设是做什么的搜狐新闻手机网
  • 网站建设竞品分析最新注册域名查询
  • 贵州省城市建设厅网站黄页引流推广网站
  • 郑州网站网站建设5118素材网站
  • 企业网络管理软件百度关键词seo年度费用
  • 做网站和做网店哪个好新东方留学机构官网
  • 桥头镇网站建设宿迁网站建设制作
  • 西安网站设计北京网站制作推广
  • 如何在电脑上做网站百度可以发布广告吗
  • 怎样做集装箱网站谷歌搜索引擎香港免费入口
  • 大数据和网站建设app推广渠道
  • 杭州做网站hzyze2022社会热点事件及看法
  • 中国核工业二三建设有限公司招聘信息长沙seo公司排名
  • 青岛路桥建设集团有限公司网站网站维护工程师
  • 外贸b2b网站用什么网站程序做制作一个网页的步骤
  • 网站建设平台中央直播淘宝关键词热度查询工具
  • 区域网站怎么做制作免费个人网站
  • 网站运营每天做啥工作站长工具免费
  • 绍兴做网站公司哪家好青岛网络推广公司排名
  • 思政网站建设管理自查报告武汉seo网站管理