LeetCode:437路径总和Ⅲ

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 {

    int count = 0;
    Map<Long,Integer> prefixMap = new HashMap<>();

    public int pathSum(TreeNode root, int targetSum) {
        prefixMap.put(0L,1);
        drive(root, 0L, targetSum);
        return count;
    }
    private void drive(TreeNode node, long currSum, int targetSum){
        if(node == null){
            return;
        }
        //1.往下遍历,将当前节点加入到map集合中
        currSum += node.val;
        //2.找之前节点中是否有我们需要的值
        long oldSum = currSum - targetSum;
        if(prefixMap.containsKey(oldSum)){
            count += prefixMap.get(oldSum);
        }
        //3.将新的值存进map中
        prefixMap.put(currSum,prefixMap.getOrDefault(currSum,0) + 1);

        drive(node.left,currSum,targetSum);
        drive(node.right,currSum,targetSum);
        //4。回溯
        prefixMap.put(currSum,prefixMap.get(currSum) - 1);
    }
}

prefixMap.put(currSum, prefixMap.getOrDefault(currSum, 0) + 1);

查找currSum出现过几次,查到了就把次数拿出来;没查到,就当作0次。然后在现有基础上+1,然后重新写入map集合中。

不能使用int count = prefixMap.get(18);因为如果为null执行+1操作会报空指针异常。

相关推荐
菜鸡爱玩4 小时前
线性代数矩阵相乘
线性代数·算法·矩阵
devilnumber7 小时前
Java 递归算法 详解 + 核心要点 + 实战运用 + 避坑指南
java·开发语言·算法
‎ദ്ദിᵔ.˛.ᵔ₎9 小时前
双指针、滑动窗口、前缀和、二分查找 算法
算法
顾北顾10 小时前
多头注意力机制
人工智能·深度学习·算法
H1785350909610 小时前
SolidWorks_基于草图的实体特征20_特征错误排查
算法·3d建模·solidworks
hujinyuan2016010 小时前
2025年12月中国电子学会青少年机器人技术等级考试试卷(二级) 真题+答案
人工智能·算法·机器人
bIo7lyA8v11 小时前
算法复杂度评估的实验统计方法与可视化的技术8
算法
李老师讲编程11 小时前
中国电子学会图形化2020.12月Scratch三级考级题
算法·scratch·信息学奥赛·图形化编程·scratch素材
退休倒计时11 小时前
【每日一题】LeetCode 53. 最大子数组和 TypeScript
数据结构·算法·leetcode·typescript