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

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

  • 前言
  • [一. 验证二叉树的前序序列化](#一. 验证二叉树的前序序列化)

前言

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

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

原题链接

思路(参考负雪明图):

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

如果一个节点是叶子节点,它的两个孩子必定是空,对于题目而言就是:

否则,一个非叶子节点存在两种可能:

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

如图:

核心思路如下:

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

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

  • 从左往右,元素不断入栈。
  • 当栈顶的前三个元素满足以下条件:前两个都是#,第三个非#。此时弹出前三个元素,再入一个#号作为替代。 4,#,# 变成#的一个体现。
  • 最终遍历完毕,如果整个栈中,还剩下一个元素,并且是#号, 说明二叉树的前序遍历是有效的。
java 复制代码
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));
}
相关推荐
HackTwoHub6 小时前
AI大模型网关存在SQL注入、附 POC 复现、影响版本LiteLLM 1.81.16~1.83.7(CVE-2026-42208)
数据库·人工智能·sql·网络安全·系统安全·网络攻击模型·安全架构
l1t7 小时前
DeepSeek总结的DuckLake构建基于 SQL 原生表格式的下一代数据湖仓
数据库·sql
KmSH8umpK7 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第八篇
数据库·redis·分布式
TDengine (老段)7 小时前
从施工监测到运营预警,桥科院用 TDengine 提升桥梁数据管理能力
大数据·数据库·物联网·时序数据库·tdengine·涛思数据
MediaTea8 小时前
AI 术语通俗词典:C4.5 算法
人工智能·算法
Navigator_Z8 小时前
LeetCode //C - 1033. Moving Stones Until Consecutive
c语言·算法·leetcode
WBluuue8 小时前
数据结构与算法:莫队(一):普通莫队与带修莫队
c++·算法
S1998_1997111609•X8 小时前
论mysql国盾shell-sfa犯罪行为集团下的分项工程及反向注入原理尐深度纳米算法下的鐌檵鄐鉎行为
网络·数据库·网络协议·百度·开闭原则
风筝在晴天搁浅8 小时前
n个六面的骰子,扔一次之后和为k的概率是多少?
算法
KmSH8umpK9 小时前
Redis分布式锁从原生手写到Redisson高阶落地,附线上死锁复盘优化方案进阶第七篇
数据库·redis·分布式