LeetCode热题(路径总和 III)

题目描述

给定一个二叉树的根节点 root ,和一个整数 targetSum ,求该二叉树里节点值之和等于 targetSum路径 的数目。

路径 不需要从根节点开始,也不需要在叶子节点结束,但是路径方向必须是向下的(只能从父节点到子节点)。

错误思路:

java 复制代码
class Solution {
    private int res = 0;
    public int pathSum(TreeNode root, int targetSum) {
        if(root == null){
            return 0;
        }
        dfs(root,targetSum,0);
        return res;
    }
    public void dfs(TreeNode root,int targetSum,int pathSum){
        if(root == null){
            return;
        }
        pathSum += root.val;
        if(pathSum == targetSum){
            res++;
        }else if(pathSum > targetSum){
            pathSum = 0;
        }
        dfs(root.left,targetSum,pathSum);
        dfs(root.right,targetSum,pathSum);
    }
}

正确代码:

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 {
    public int pathSum(TreeNode root, long targetSum) {
        if(root == null){
            return 0;
        }
        int ret = dfs(root,targetSum);
        ret += pathSum(root.left,targetSum);
        ret += pathSum(root.right,targetSum);
        return ret;
    }
    public int dfs(TreeNode root,long targetSum){
        int ret = 0;
        if(root == null){
            return 0;
        }
        int val = root.val;
        if(val == targetSum){
            ret++;
        }
        ret += dfs(root.left,targetSum-val);
        ret += dfs(root.right,targetSum-val);
        return ret;
    }
}

反思复盘:

1.只考虑了以跟节点出发的情况,没有递归左子树和右子树。

2.计算和的方式不对,官方题解巧妙的使用每遍历一个节点和的值减少,这样就不用再用一个变量记录当前和了。

3.需要巧妙使用递归多次计算以不节点为起点的路径。

4.使用递归如果数据量比较大的话,容易超时,本题还可以进一步优化。

相关推荐
罗湖老棍子13 小时前
【区间DP】括号序列:如何求解最长合法子序列?(POJ 2955)
算法·动态规划·区间dp·区间动态规划·端点匹配型
王德博客13 小时前
【实现常见排序算法】直接插入排序的算法思想
数据结构·算法·排序算法
m0_5648768413 小时前
分布式训练DP与DDP
人工智能·深度学习·算法
纤纡.13 小时前
逻辑回归实战进阶:交叉验证与采样技术破解数据痛点(一)
算法·机器学习·逻辑回归
重生之后端学习13 小时前
146. LRU 缓存
java·数据结构·算法·leetcode·职场和发展
程曦曦13 小时前
原地删除有序数组重复项:双指针法的艺术与实现
数据结构·算法·leetcode
你怎么知道我是队长13 小时前
C语言---排序算法6---递归归并排序法
c语言·算法·排序算法
智驱力人工智能13 小时前
景区节假日车流实时预警平台 从拥堵治理到体验升级的工程实践 车流量检测 城市路口车流量信号优化方案 学校周边车流量安全分析方案
人工智能·opencv·算法·安全·yolo·边缘计算
MicroTech202513 小时前
微算法科技(NASDAQ :MLGO)抗量子攻击区块链共识机制:通过量子纠缠态优化节点验证流程,降低计算复杂度
科技·算法·区块链
pp起床13 小时前
贪心算法 | part01
算法·贪心算法