码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 想要精通算法和SQL的成长之路 - 验证二叉树的前序序列化


    想要精通算法和SQL的成长之路 - 验证二叉树的前序序列化

    • 前言
    • 一. 验证二叉树的前序序列化

    前言

    想要精通算法和SQL的成长之路 - 系列导航

    一. 验证二叉树的前序序列化

    原题链接
    在这里插入图片描述
    在这里插入图片描述
    思路(参考负雪明图):

    1. 首先我们看题目所给的字符串,是一个先序遍历的结果。也就是说:父节点–> 左节点–>右节点,这么一个遍历顺序。
    2. 那么我们可以先校验左子树是否是合法的,再判断右子树是否合法。从而决定当前树是否有效。

    如果一个节点是叶子节点,它的两个孩子必定是空,对于题目而言就是:
    在这里插入图片描述
    否则,一个非叶子节点存在两种可能:

    • 两个孩子都非空。
    • 一个孩子为空,一个孩子非空。

    如图:
    在这里插入图片描述
    核心思路如下:

    • 如果遇到叶子节点(两个孩子都为空)的时候,将当前叶子节点看做是一个空节点。
    • 那么对于该叶子节点的父节点而言:两个孩子都变成了空节点,那么父节点就是叶子节点。以此往上递推。即 4,#,# 变成#
    • 例如:[9,#2,#,6,#,#] => [9,#,2,#,#] => [9,#,#] => [#]。

    我们用栈来遍历这个前序遍历的结果,用自底向上的特性去操作:

    • 从左往右,元素不断入栈。
    • 当栈顶的前三个元素满足以下条件:前两个都是#,第三个非#。此时弹出前三个元素,再入一个#号作为替代。 4,#,# 变成#的一个体现。
    • 最终遍历完毕,如果整个栈中,还剩下一个元素,并且是#号, 说明二叉树的前序遍历是有效的。
    public boolean isValidSerialization(String preorder) {
        LinkedList<String> stack = new LinkedList<>();
        for (String str : preorder.split(",")) {
            stack.push(str);
            // 如果栈顶的前两个元素都是#号,并且第三个元素非 # 号,那么弹出前三个元素,并入一个#号
            while (stack.size() >= 3
                    && "#".equals(stack.get(0))
                    && "#".equals(stack.get(1))
                    && !"#".equals(stack.get(2))) {
                stack.pop();
                stack.pop();
                stack.pop();
                stack.push("#");
            }
        }
        return stack.size() == 1 && "#".equals(stack.get(0));
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
  • 相关阅读:
    鸿蒙OS元服务开发说明:【WebGL网页图形库开发接口】
    5分钟打造好用好看API文档
    k8s中如何使用gpu、gpu资源讲解、nvidia gpu驱动安装
    【C++】搜索二叉树/KVL树
    基于神经网络的手写汉字提取与书写评分模型研究
    Linux驱动开发(十三)---USB驱动HID开发学习(鼠标)
    docker 常用命令 快捷命令
    加强堆结构说明
    c++ 重载、重写、覆盖
    windows 开启ssh服务器
  • 原文地址:https://blog.csdn.net/Zong_0915/article/details/133521759
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号