【递归】【回溯】Leetcode 112. 路径总和 113. 路径总和 II

【递归】【回溯】Leetcode 112. 路径总和 113. 路径总和 II

  • [112. 路径总和](#112. 路径总和)
    • [解法:递归 有递归就有回溯 记得return正确的返回上去](#解法:递归 有递归就有回溯 记得return正确的返回上去)
  • [113. 路径总和 II](#113. 路径总和 II)
    • [解法 递归](#解法 递归)

如果需要搜索整棵二叉树 ,那么递归函数就不要返回值
如果要搜索其中一条符合条件的路径 ,递归函数就需要返回值,因为遇到符合条件的路径了就要及时返回

112. 路径总和

---------------🎈🎈题目链接🎈🎈-------------------

解法:递归 有递归就有回溯 记得return正确的返回上去

count初始等于targetsum,逐次减,如果到了叶子结点正好count为0,那么就返回true

终止条件:if(root.left = null && root.right = null && count=0){ return true; }

时间复杂度O(N)

空间复杂度O(N)

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    public boolean hasPathSum(TreeNode root, int targetSum) {
        // 终止条件
        if(root == null) return false;
        int count = targetSum-root.val;
        return help(root,count);
    }
    
    public boolean help(TreeNode root, int count){
        if(root.left==null && root.right==null && count==0){
            return true;
        }
        if(root.left==null && root.right==null && count!=0){
            return false;
        }

        // 左
        if(root.left != null){
            if(help(root.left, count-root.left.val)){
                return true;
            }
        }
       
        // 右
        if(root.right != null){
            if(help(root.right, count-root.right.val)){
                return true;
            }
        }
        return false;

    }
    
}

113. 路径总和 II

---------------🎈🎈题目链接🎈🎈-------------------

解法 递归

时间复杂度O(N)

空间复杂度O(N)

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode() {}
 *     TreeNode(int val) { this.val = val; }
 *     TreeNode(int val, TreeNode left, TreeNode right) {
 *         this.val = val;
 *         this.left = left;
 *         this.right = right;
 *     }
 * }
 */
class Solution {
    List<List<Integer>> finalresult = new ArrayList<>();
    public List<List<Integer>> pathSum(TreeNode root, int targetSum) {
        List<Integer> result = new ArrayList<>();
        if(root == null) return finalresult;
        result.add(root.val);
        helper(root,targetSum-root.val,result);
        return finalresult;

    }
    public void helper(TreeNode root, int count, List<Integer> result){

        if(root.left == null && root.right==null && count==0){
            finalresult.add(new ArrayList<>(result)); 
            // 这里千万不能finalresult.add(result) 这就成了添加result的引用,每次都会变
        }

        // 左
        if(root.left != null){
            result.add(root.left.val);
            helper(root.left, count-root.left.val,result);
            result.remove(result.size()-1); // 回溯
        }
        // 右
        if(root.right != null){
            result.add(root.right.val);
            helper(root.right,count-root.right.val,result);
            result.remove(result.size()-1); // 回溯
        }
    }
}
相关推荐
he___H14 分钟前
数据结构-移位
数据结构
电子_咸鱼39 分钟前
LeetCode——Hot 100【电话号码的字母组合】
数据结构·算法·leetcode·链表·职场和发展·贪心算法·深度优先
仰泳的熊猫40 分钟前
LeetCode:785. 判断二分图
数据结构·c++·算法·leetcode
rit84324991 小时前
基于MATLAB实现基于距离的离群点检测算法
人工智能·算法·matlab
my rainy days3 小时前
C++:友元
开发语言·c++·算法
haoly19893 小时前
数据结构和算法篇-归并排序的两个视角-迭代和递归
数据结构·算法·归并排序
微笑尅乐3 小时前
中点为根——力扣108.讲有序数组转换为二叉搜索树
算法·leetcode·职场和发展
小梁努力敲代码3 小时前
java数据结构--List的介绍
java·开发语言·数据结构
摸鱼的老谭3 小时前
构建Agent该选Python还是Java ?
java·python·agent
lang201509284 小时前
Spring Boot 官方文档精解:构建与依赖管理
java·spring boot·后端