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

【力扣hot100题】(047)路径总和Ⅲ

已经变成了……不用递归就做不出题的样子…………

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    int pathSum(TreeNode* root, int targetSum) {
        if(root==nullptr) return 0;
        return path(root,targetSum)+pathSum(root->left,targetSum)+pathSum(root->right,targetSum);
    }
    int path(TreeNode* root,long int targetSum){
        if(root==nullptr) return 0;
        int own=0;
        if(root->val==targetSum) own+=1;
        return own+path(root->left,targetSum-root->val)+path(root->right,targetSum-root->val);
    }
};

用时还是太高了,主播主播,你的递归确实很强,但还是太吃时间了,有没有更加简单又快速的英方法推荐一下吗?有的有的,那就是使用前缀和。

方法就是每次都记录走过的路线的节点之和(sum),和到路径上每个节点时走过的路径的和(hash),每次查看hash中有没有sum-target,递归回溯时要删除对应hash并且恢复sum,这样就能保证不会记录到别的路径上。

虽然还是递归,但是时间复杂度由O(n^{2})变为了O(n)。

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:
    unordered_map<long int,int> hash;
    int result=0;
    long int sum=0;
    int pathSum(TreeNode* root, int targetSum) {
        if(root==nullptr) return 0;
        sum+=root->val;
        if(hash[sum-targetSum]!=0) result+=hash[sum-targetSum];
        hash[sum]++;
        if(sum==targetSum) result+=1;
        pathSum(root->left,targetSum);
        pathSum(root->right,targetSum);
        hash[sum]--;
        sum-=root->val;
        return result;
    }
};

相关文章:

  • 如何在Android中使用匿名内部类?
  • 人工智能混合编程实践:C++调用封装好的DLL进行图像超分重建
  • MinIO 入门指南:高性能对象存储的安装与使用
  • 国内使用Claude 3.7 sonnet的6种方法及Cursor+Claude3.7实现从原型到app开发
  • 034-QSharedMemory
  • 人工智能在医疗领域的创新应用与挑战
  • HC32F460 - SPI+DMA+TFT
  • 蓝桥杯2024省赛PythonB组——日期问题
  • 【XTerminal】【树莓派】Linux系统下的函数调用编程
  • UE5 + Rider + VsCode 接入腾讯的 Puerts 脚本
  • XEOS 与 AutoMQ 推出联合方案,共筑云原生 Kafka 新生态
  • Pytorch深度学习框架60天进阶学习计划 - 第35天:模型解释性
  • C++学习笔记 | malloc calloc realloc的作用以及区别
  • AI大模型从0到1记录学习 day13
  • 【Docker 那些事儿】如何安全地停止、删除容器
  • Flutter vs React Native:跨平台移动开发框架对比
  • GPT-4o 图像生成:重新定义 AI 视觉创作边界
  • PHP基础二【变量/输出/数据类型/常量/字符串/运算符】
  • Day 3:Leetcode 比特位计数+只出现一次的数字 II
  • DDR(双倍数据率内存)在路由中扮演的角色