LeetCode 814. 二叉树剪枝

Posted 菜鸡的世界

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LeetCode 814. 二叉树剪枝相关的知识,希望对你有一定的参考价值。

题目链接

814. 二叉树剪枝

题目分析

这个题目给一棵二叉树,如果当前子树中不存在1,就要把这个子树从整棵树上剪掉。
遇到树的问题我们一般用递归的方法解决,递归主要有以下几个问题

  • 结束条件
  • 子递归条件
  • 子递归的返回值的处理
    对于树来说,结束条件一般是访问到空结点。在本题中也一样,同时我们每次的子递归应该是root结点的左孩子和右孩子。同时我们要对当前结点的左孩子右孩子进行剪枝,所以返回的值应该体现在树上。
    最后我们还需要判断,如果当前结点的左孩子右孩子都被剪去之后,当前结点是否存在1,如果不存在的话也要返回空给上一层递归,用于剪枝。
    否则我们直接就返回当前结点即可。

代码实现

/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public TreeNode pruneTree(TreeNode root) {
        if(root == null){
            return null;
        }
        root.left = pruneTree(root.left);
        root.right = pruneTree(root.right);
        if(root.left == null && root.right == null){
            return root.val == 1?root:null;
        }else{
            return root;
        }
    }
}




以上是关于LeetCode 814. 二叉树剪枝的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 814. 二叉树剪枝

LeetCode 814 二叉树剪枝[dfs] HERODING的LeetCode之路

leetcode 814. 二叉树剪枝 时间击败100.00% 内存击败84.62%

LeetCode 0814. 二叉树剪枝

每日一题814. 二叉树剪枝

582,DFS解二叉树剪枝