当前位置: 首页 > article >正文

Leetcode437. 路径总和 III(HOT100)

链接

我的代码:

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);

    }
};

更好的代码:
 

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存储的是某和出现了多少次,这个和可能会溢出。 


http://www.kler.cn/a/413324.html

相关文章:

  • Unity版本使用情况统计(更新至2024年11月)
  • 3D扫描对文博行业有哪些影响?
  • 111. UE5 GAS RPG 实现角色技能和场景状态保存到存档
  • 一个简单的ASP.NET 一致性返回工具库
  • 【深度学习|目标跟踪】StrongSort 详解(以及StrongSort++)
  • UE5 实现组合键触发事件的方法
  • BERT的中文问答系统38
  • 猎户星空发布MoE大模型,推出AI数据宝AirDS
  • unity中的Horizontal和Vertical介绍
  • 深入解析经典排序算法:原理、实现与优化
  • 富格林:有效追损正确提高出金
  • 部署 DeepSpeed以推理 defog/sqlcoder-70b-alpha 模型
  • Qt Qt::UniqueConnection 底层调用
  • 多目标优化算法——多目标粒子群优化算法(MOPSO)
  • uni-app 蓝牙开发
  • C++设计模式行为模式———策略模式
  • python控制鼠标,键盘,adb
  • 使用SQL按每小时统计数据的方法
  • C#设计模式——抽象工厂模式(重点)
  • Python使用ffmpeg进行本地视频拉流,并使用训练模型识别人脸,并将识别后的模型推流源码
  • frida_hook_libart(简单解释)
  • 介绍SSD硬盘
  • C#里怎么样使用LINQ的let关键字实现查询?
  • 基于Qt实现的自定义树结构容器:设计与应用
  • 摄像头原始数据读取——ffmpeg(av_read_frame)
  • springboot学习-分页/排序/多表查询的例子