Leetcode437. 路径总和 III(HOT100)

链接

我的代码:

cpp 复制代码
class Solution {
public:
    int res = 0;
    int pathSum(TreeNode* root, int targetSum) {
        if(!root)return 0;
        dfs(root,targetSum);
        pathSum(root->left,targetSum);
        pathSum(root->right,targetSum);
        return res;
    }
    void dfs(TreeNode*root,long long targetSum){
        if(!root)return;
        targetSum-=root->val;
        if(targetSum==0){
            res++;
        }
        dfs(root->left,targetSum);
        dfs(root->right,targetSum);

    }
};

更好的代码:

cpp 复制代码
class Solution {
public:
    unordered_map<long long,int> cnt;
    int res = 0;
    int pathSum(TreeNode* root, int targetSum) {
        cnt[0] = 1;
        dfs(root,targetSum,0);
        return res;
    }
    void dfs(TreeNode*root,int targetSum,long long cur){
        if(!root)return;
        cur+=root->val;
        res+=cnt[cur-targetSum];
        cnt[cur]++;
        dfs(root->left,targetSum,cur),dfs(root->right,targetSum,cur);
        cnt[cur]--;
    }
};

第二次这个代码刚开始写的时候:没有把cnt中key的类型从int改为long long,然后一直疑惑:dfs形参cur的类型就是int啊...........

原来cnt的key的类型也要改,因为cnt存储的是某和出现了多少次,这个和可能会溢出。

相关推荐
闪电麦坤958 分钟前
数据结构:递归的种类(Types of Recursion)
数据结构·算法
Gyoku Mint1 小时前
机器学习×第二卷:概念下篇——她不再只是模仿,而是开始决定怎么靠近你
人工智能·python·算法·机器学习·pandas·ai编程·matplotlib
纪元A梦1 小时前
分布式拜占庭容错算法——PBFT算法深度解析
java·分布式·算法
px不是xp1 小时前
山东大学算法设计与分析复习笔记
笔记·算法·贪心算法·动态规划·图搜索算法
枫景Maple2 小时前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄2 小时前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄2 小时前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯
小wanga3 小时前
【递归、搜索与回溯】专题三 穷举vs暴搜vs回溯vs剪枝
c++·算法·机器学习·剪枝
天宫风子3 小时前
线性代数小述(一)
线性代数·算法·矩阵·抽象代数