814. 二叉树剪枝 中等
给定二叉树根结点 root ,此外树的每个结点的值要么是 0,要么是 1。
返回移除了所有不包含 1 的子树的原二叉树。
( 节点 X 的子树为 X 本身,以及所有 X 的后代。)
示例1:
输入: [1,null,0,0,1]
输出: [1,null,0,null,1]
解释:
只有红色节点满足条件“所有不包含 1 的子树”。
右图为返回的答案。
示例2:
输入: [1,0,1,0,0,0,1]
输出: [1,null,1,null,1]
示例3:
输入: [1,1,0,1,1,0,1,0]
输出: [1,1,0,1,1,null,1]
说明:
- 给定的二叉树最多有 100 个节点。
- 每个节点的值只会为 0 或 1 。
代码参考:
package main
import "fmt"
func main() {
root := &TreeNode{Val: 1}
root.Right = &TreeNode{Val: 0}
root.Right.Left = &TreeNode{Val: 0}
root.Right.Right = &TreeNode{Val: 1}
newRoot := pruneTree(root)
fmt.Println(newRoot)
fmt.Println(newRoot.Left)
fmt.Println(newRoot.Right)
fmt.Println(newRoot.Right.Left)
fmt.Println(newRoot.Right.Right) // bingo
}
// 其实就是一个后序遍历,一步一步摘除 0 叶子
func pruneTree(root *TreeNode) *TreeNode {
if root == nil {
return nil
}
root.Left = pruneTree(root.Left)
root.Right = pruneTree(root.Right)
if root.Left == nil && root.Right == nil && root.Val == 0 {
return nil
}
return root
}
最后编辑: kuteng 文档更新时间: 2021-06-05 10:16 作者:kuteng