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

相关推荐
气泡音人声分离15 分钟前
技术解析|均衡器(EQ)工作原理与实操指南:从频率拆分到听感优化
算法·均衡器·音频剪辑
weixin_4130632125 分钟前
复现 MatchED 边缘检测模型(单张图片重复8次,训练200 epoch)
python·算法·计算机视觉·边缘检测模型
2601_9624408428 分钟前
计算机毕业设计之jsp教室管理系统
java·开发语言·笔记·分布式·算法·课程设计·推荐算法
AI视频剪辑官30 分钟前
播客切片工具选型核心评价维度
网络·人工智能·算法
复杂网络3 小时前
AI 不睡觉,但它比你更会做实验
算法
贵慜_Derek4 小时前
MAI-04|干净数据在工程上意味着什么:MAI 预训练数据治理
人工智能·算法·llm
想吃火锅10055 小时前
【leetcode】146.LRU缓存js
算法·leetcode·缓存
vibecoding日记21 小时前
双非如何快速入职字节等大厂大模型?真实案例分析:推理优化和投机解码
算法·求职·大模型工程师