剑指Offer || 050.路径总和|||

2023-10-21 07:52
文章标签 路径 offer 总和 050

本文主要是介绍剑指Offer || 050.路径总和|||,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

题目

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

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

示例 1:

输入:root = [10,5,-3,3,2,null,11,3,-2,null,1], targetSum = 8
输出:3
解释:和等于 8 的路径有 3 条,如图所示。

示例 2:

输入:root = [5,4,8,11,null,13,4,7,2,null,null,5,1], targetSum = 22
输出:3

提示:

  • 二叉树的节点个数的范围是 [0,1000]
  • -109 <= Node.val <= 109 
  • -1000 <= targetSum <= 1000 

注意:本题与主站 437 题相同:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

LCR 050. 路径总和 III - 力扣(LeetCode)

题解

思路一:暴力解法,枚举每个结点作为根,在对枚举的每颗子树进行dfs(即两次dfs),判断是否存在targetSum。 注意:过程sum可能会溢出,故设为long。

代码:

class Solution {long target;int ans = 0;public void dfs(TreeNode t, long sum) {if (t == null) return;if (sum + t.val == target)ans++;dfs(t.left, sum + t.val);dfs(t.right, sum + t.val);}public void dfs1(TreeNode t){if(t == null) return;dfs(t, 0);dfs1(t.left);dfs1(t.right);}public int pathSum(TreeNode root, int targetSum) {this.target = targetSum;dfs1(root);return ans;}
}

思路二:前缀和思想。每次到一个新的结点,总是会重复计算结点间的路径和,于是可以使用一个map<从根节点到当前结点的路径长度,有多少条该路径>,来记录路径sum,然后当前sum-之前的sum==target的,即是一条路径。

有两个点需要注意:1.根节点为空路径,map要添加<0,1>。

                                 2.每个子树操作完之后,要消除该子树对其他子树的影响,即map的value值是会减少的。

代码:

class Solution {//map<从根节点到当前结点的路径长度,有多少条该路径>Map<Long, Integer> sumCountMap = new HashMap<Long, Integer>();public int pathSum(TreeNode root, int targetSum) {if (root == null)  return 0;sumCountMap.put(0L, 1);//起点的空路径return getCounts(root, root.val, targetSum);}public int getCounts(TreeNode node, long sum, int targetSum) {//递归的每个子树里都有一个新的count加进来。int count = sumCountMap.getOrDefault(sum - targetSum, 0);sumCountMap.put(sum, sumCountMap.getOrDefault(sum, 0) + 1);if (node.left != null) count += getCounts(node.left, sum + node.left.val, targetSum);if (node.right != null) count += getCounts(node.right, sum + node.right.val, targetSum);//从子树里退出去的时候,消除当前的sum数量对其他子树的影响sumCountMap.put(sum, sumCountMap.get(sum) - 1);return count;}
}

这篇关于剑指Offer || 050.路径总和|||的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/252993

相关文章

hdu2544(单源最短路径)

模板题: //题意:求1到n的最短路径,模板题#include<iostream>#include<algorithm>#include<cstring>#include<stack>#include<queue>#include<set>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#i

poj 1734 (floyd求最小环并打印路径)

题意: 求图中的一个最小环,并打印路径。 解析: ans 保存最小环长度。 一直wa,最后终于找到原因,inf开太大爆掉了。。。 虽然0x3f3f3f3f用memset好用,但是还是有局限性。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#incl

【408DS算法题】039进阶-判断图中路径是否存在

Index 题目分析实现总结 题目 对于给定的图G,设计函数实现判断G中是否含有从start结点到stop结点的路径。 分析实现 对于图的路径的存在性判断,有两种做法:(本文的实现均基于邻接矩阵存储方式的图) 1.图的BFS BFS的思路相对比较直观——从起始结点出发进行层次遍历,遍历过程中遇到结点i就表示存在路径start->i,故只需判断每个结点i是否就是stop

Android Environment 获取的路径问题

1. 以获取 /System 路径为例 /*** Return root of the "system" partition holding the core Android OS.* Always present and mounted read-only.*/public static @NonNull File getRootDirectory() {return DIR_ANDR

图的最短路径算法——《啊哈!算法》

图的实现方式 邻接矩阵法 int[][] map;// 图的邻接矩阵存储法map = new int[5][5];map[0] = new int[] {0, 1, 2, 3, 4};map[1] = new int[] {1, 0, 2, 6, 4};map[2] = new int[] {2, 999, 0, 3, 999};map[3] = new int[] {3, 7

vcpkg子包路径批量获取

获取vcpkg 子包的路径,并拼接为set(CMAKE_PREFIX_PATH “拼接路径” ) import osdef find_directories_with_subdirs(root_dir):# 构建根目录下的 "packages" 文件夹路径root_packages_dir = os.path.join(root_dir, "packages")# 如果 "packages"

代码随想录训练营day37|52. 携带研究材料,518.零钱兑换II,377. 组合总和 Ⅳ,70. 爬楼梯

52. 携带研究材料 这是一个完全背包问题,就是每个物品可以无限放。 在一维滚动数组的时候规定了遍历顺序是要从后往前的,就是因为不能多次放物体。 所以这里能多次放物体只需要把遍历顺序改改就好了 # include<iostream># include<vector>using namespace std;int main(){int n,m;cin>>n>>m;std::vector<i

jmeter依赖jar包找不到类路径

这两天我在纠结这个问题,为啥我maven打包放在jmeter路径下后,jmeter的bean Shell 就是找不到这个类。纠结很久解开了。我记录下,留给后来的朋友。   Error invoking bsh method: eval Sourced file: inline evaluation of: ``import org.apache.jmeter.protocol.http.s

运行.bat文件,如何在Dos窗口里面得到该文件的路径

把java代码打包成.jar文件,编写一个.bat文件,执行该文件,编译.jar包;(.bat,.jar放在同一个文件夹下) 运行.bat文件,如何在Dos窗口里面得到该文件的路径,并运行.jar文件: echo 当前盘符:%~d0 echo 当前路径:%cd% echo 当前执行命令行:%0 echo 当前bat文件路径:%~dp0 echo 当前bat文件短路径:%~sdp0 nc

代码随想录算法训练营Day37|完全背包问题、518.零钱兑换II、377. 组合总和 Ⅳ、70. 爬楼梯(进阶版)

完全背包问题                  和01背包最大区别就是一个物品可以重复放多次,因此遍历空间时可以从前往后。 import java.util.*;public class Main{public static void main (String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt