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操作会报空指针异常。

相关推荐
♡すぎ♡10 小时前
ShaderLab:PBR+IBL(ShaderToy Translation)
算法·计算机图形学·着色器·pbr·ibl
AI周红伟10 小时前
创业10年,张一鸣成长的2个基本方法论
面试·职场和发展
Shadow(⊙o⊙)10 小时前
前缀和:和可被K整除的子数组(normal)
数据结构·c++·算法
世纪末的小黑10 小时前
【LeetCode自用】LeetCode自用记录贴,题目一:两数之和
数据结构·算法·leetcode
兰令水10 小时前
topcode【随机算法题】【2026.5.22打卡-java版本】
java·算法·leetcode
Brilliantwxx10 小时前
【C++】 认识STL set与map(基础接口+题目OJ运用)
开发语言·数据结构·c++·笔记·算法
05候补工程师10 小时前
【线性代数】核心考点复习笔记:二次型配方法、施密特正交化步骤与特征值经典题型详解
经验分享·笔记·线性代数·考研·算法
Deep-w10 小时前
【MATLAB】基于遗传算法的直流电机 PI 控制器参数优化研究
开发语言·算法·matlab
暴力求解10 小时前
数据结构---二叉树及堆的实现
数据结构·算法·二叉树