814.二叉树剪枝
【LetMeFly】814.二叉树剪枝
力扣题目链接:https://leetcode.cn/problems/binary-tree-pruning/
给你二叉树的根结点 root
,此外树的每个结点的值要么是 0
,要么是 1
。
返回移除了所有不包含 1
的子树的原二叉树。
节点 node
的子树为 node
本身加上所有 node
的后代。
示例 1:
输入:root = [1,null,0,0,1] 输出:[1,null,0,null,1] 解释: 只有红色节点满足条件“所有不包含 1 的子树”。 右图为返回的答案。
示例 2:
输入:root = [1,0,1,0,0,0,1] 输出:[1,null,1,null,1]
示例 3:
输入:root = [1,1,0,1,1,0,1,0] 输出:[1,1,0,1,1,null,1]
提示:
- 树中节点的数目在范围
[1, 200]
内 Node.val
为0
或1
方法一:DFS
递归,返回结果的同时进行修剪。
因为涉及到一个节点的所有子树,因此很适合深搜DFS。
构建一个函数isZero
,用来判断一个节点是否是某个全0子树
的根。同时,如果这个节点的左子树是全0子树,就剪掉这个节点的左子树;右子树同理。
1 |
|
- 时间复杂度$O(N)$,其中$N$是节点的个数
- 空间复杂度$O(N)$,空间复杂度主要来自递归
AC代码
C++
1 |
|
同步发文于CSDN,原创不易,转载请附上原文链接哦~
Tisfy:https://letmefly.blog.csdn.net/article/details/125918905
814.二叉树剪枝
https://blog.letmefly.xyz/2022/07/21/LeetCode 0814.二叉树剪枝/