码迷,mamicode.com
首页 > 其他好文 > 详细

LeetCode 814. 二叉树剪枝

时间:2020-06-29 13:16:16      阅读:43      评论:0      收藏:0      [点我收藏+]

标签:==   链接   题目   剪枝   lan   返回值   init   root   null   

题目链接

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. 二叉树剪枝

标签:==   链接   题目   剪枝   lan   返回值   init   root   null   

原文地址:https://www.cnblogs.com/ZJPaang/p/13207414.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!