Java实现 LeetCode 814 二叉树剪枝 (遍历树)

浅浅的花香味﹌ 2023-03-13 01:55 108阅读 0赞

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 。

  1. /** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val = x; } * } */
  2. class Solution {
  3. public TreeNode pruneTree(TreeNode root) {
  4. if(root == null) {
  5. return null;
  6. }
  7. root.left = pruneTree(root.left);
  8. root.right = pruneTree(root.right);
  9. if(root.left == null && root.right == null && root.val == 0) {
  10. return null;
  11. }
  12. return root;
  13. }
  14. }

发表评论

表情:
评论列表 (有 0 条评论,108人围观)

还没有评论,来说两句吧...

相关阅读

    相关 814. 剪枝

    给定二叉树根结点 `root` ,此外树的每个结点的值要么是 0,要么是 1。 返回移除了所有不包含 1 的子树的原二叉树。 ( 节点 X 的子树为 X 本身,以及所有 X