算法喜刷刷之验证二叉树的前序序列化
题目难度:**中等**
题目描述:序列化二叉树的一种方法是使用前序遍历。当我们遇到一个非空节点时,我们可以记录下这个节点的值。如果它是一个空节点,我们可以使用一个标记值记录,例如 #
。
复制代码
示例 1:
输入: "9,3,4,#,#,1,#,#,2,#,6,#,#"
输出: true
示例 2:
输入: "1,#"
输出: false
示例 3:
输入: "9,#,#,1"
输出: false
解题步骤:
复制代码
思路说明:
我们知道二叉树有一个性质就是整棵树叶子节点的个数比内部节点的个数大 1,当然在遍历的过程中,叶子节点的个数一定是小于等于内部节点的个数的,如果不满足这个条件,证明有根节点为空,直接返回 false,遍历完成后,只需要验证一下上面说的性质就可以了。
评论