leetcode437 路径总和III-哈希表+前缀和

题目

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

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

示例

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

解析

这道题单单使用dfs的方法的话,基本上还是可以想到思路的:

/*** Definition for a binary tree node.* type TreeNode struct {*     Val int*     Left *TreeNode*     Right *TreeNode* }*/
func pathSum(root *TreeNode, targetSum int) int {if root == nil {return 0}res := rootSum(root, targetSum)res += pathSum(root.Left, targetSum)res += pathSum(root.Right, targetSum)return res
}func rootSum(root *TreeNode, targetSum int) int {res := 0if root == nil {return res}if root.Val == targetSum {res++}res += rootSum(root.Left, targetSum-root.Val)res += rootSum(root.Right, targetSum-root.Val)return res
}

然后实际上,这道题最好的解法是哈希表+前缀和的思路:
在二叉树上,前缀和相当于从根节点开始的路径元素和。用哈希表 cnt 统计前缀和的出现次数,当我们递归到节点 node时,设从根到 node 的路径元素和为 s,那么就找到了 cnt[s−targetSum]个符合要求的路径,加入答案。
在其中的恢复现场部分:如果不恢复现场,当我们递归完左子树,要递归右子树时,cnt中还保存着左子树的数据。但递归到右子树,要计算的路径并不涉及到左子树的任何节点,如果不恢复现场,cnt中统计的前缀和个数会更多,我们算出来的答案可能比正确答案更大。

func pathSum(root *TreeNode, targetSum int) (ans int) {cnt := map[int]int{0: 1} // 01是防止包含根节点的时候找不到var dfs func(*TreeNode, int)dfs = func(node *TreeNode, s int) {if node == nil {return}// 判断是否存在符合条件的前缀和s += node.Valans += cnt[s-targetSum]// 将当前前缀和记录下来cnt[s]++// 继续向下递归dfs(node.Left, s)dfs(node.Right, s)// 回溯,恢复状态cnt[s]--return}dfs(root, 0)return
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/14113.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

PHP发票真假API、医疗电子票据查验、发票识别接口开发示例

“营”“增”两种税是主流的流转税种,是两个独立而不能交叉的税种。也就是说交增值税的话就不交营业税,而交了营业税就不需要交增值税。而且,两者在征收的对象、征税范围、计税的依据、税目、税率以及征收管理等都有所不同,增值税…

618哪些好物值得入手?必备数码好物清单分享

618购物节又来了!一大波智能好物来袭!随着科技的日新月异,智能产品已成为我们生活中不可或缺的一部分,它们不仅炫酷,还能让你生活更便捷。想知道今年都有哪些黑科技新品吗?赶紧跟我们一起,我们将详细介绍这些热门好物。一堆超炫酷…

免费SSL证书与付费SSL证书:特性对比与适用场景解析

近几年随着互联网的发展,线上教育、线上办公,线上学习等逐渐融入我们的生活。与此同时,信息数据泄露等网络安全问题也日益突出,为了保护企业与用户的隐私信息,越来越多的公司选择安装SSL证书来保护网站和平台的数据安全…

poi操作word模板,对原有的word修改

/*** 化工园区调查表** param templatePath* param outPath* param parkInterview*/public static String getDocx(String templatePath, String outPath, ParkInterview parkInterview){File file new File(templatePath);File file1 new File(outPath);if(!file1.exists()…

计算机网络数据链路层知识点总结

3.1 数据链路层功能概述 (1)知识总览 (2)数据链路层的研究思想 (3)数据链路层基本概念 (4)数据链路层基本功能 3.1 封装成帧和透明传输 (1)数据链路层功能…

简单几步免费申请通配符/泛域名SSL证书

申请免费通配符SSL证书的过程可能会因不同的证书颁发机构(CA)而异,但以下是一般步骤,基于当前可获得的信息,特别是提及了JoySSL作为提供免费通配符证书的服务商之一。请注意,情况可能会随时间变化,因此建议直接访问相关…

贪心算法2(c++)

最大子矩阵 描述 已知矩阵的大小定义为矩阵中所有元素的和。给定一个矩阵,你的任务是找到最大的非空(大小至少是1*1)子矩阵。 比如,如下4*4的矩阵 0- 2 -7 0 9 2 -6 2 -4 1 -4 1 -1 8 0-2 的最大子矩阵是 9 2 -4 1 -18 这个子矩阵的大小是15。 输入…

文件传输服务应用1——java集成smb2/3详细教程和windows共享服务使用技巧

在实际项目开发过程中,读取网络资源或者局域网内主机的文件是必要的操作和需求。而FTP(文件传输协议)和SMB(服务器消息块)是两种最为常见的文件传输协议。它们各自在文件传输领域拥有独特的优势和特点,但同…

【NOIP2013普及组复赛】题4:车站分级

题4:车站分级 【题目描述】 一条单向的铁路线上,依次有编号为 1 , 2 , … , n 1,2,…,n 1,2,…,n 的 n n n 个火车站。每个火车站都有一个级别,最低为 1 1 1 级。现有若干趟车次在这条线路上行驶,每一趟都满足如下要求&#…

Q-Learning学习笔记-李宏毅

introduction 学习的并不是policy,而是学习critic,critic用来评价policy好还是不好;一种critic:state value function V π ( s ) V^\pi(s) Vπ(s)是给定一个policy π \pi π,在遇到state s s s之后累积的reward的…

狙击交易策略加强版与普通版5点区别,WeTrade众汇盘点

通过之前的文章想必各位投资者都已经知道了什么是狙击交易策略,以及如何使用,WeTrade众汇本着严谨的态度,对狙击战术进行了大致梳理,发现其主要更新集中在2015至2017年间。但是研发者并未止步于此。2018年之后,他们又推…

C++调用dll的方法

代码如下&#xff1a; #pragma once#include <Windows.h>using namespace std;class Test_ExportDll { public:typedef char* (_stdcall *Get_dll_versionPROC)(void);Get_dll_versionPROC Get_dll_version;typedef bool (_stdcall *Port_ClosePROC)(unsigned int Index…

子分支想主分支发起合并请求

请求合并 1.点击 git Web 页右上角打开 Merge requests 进入新页&#xff0c;点击右上角。注意选择要合并的项目 2.左边是源分支&#xff0c;右边是要合并的目标分支。 3.最后点击左下角绿色按钮 4.第一个红框 Assignee&#xff0c;选择要通知去合并的人。第二个红框不动&#…

Java面试题--基础篇,更新中...

1、 Java语言有哪些特点 简单易学、有丰富的类库 面向对象&#xff08;Java最重要的特性&#xff0c;让程序耦合度更低&#xff0c;内聚性更高&#xff09; 与平台无关性&#xff08;JVM是Java跨平台使用的根本&#xff09; 可靠安全 支持多线…

【shell】 break和continue的区别

break 是用于循环退出&#xff0c;而 continue 是结束本次循环&#xff0c;进入下一次循环。 1 break的使用 [rootopenEuler ~]# cat break.sh #!/bin/bashfor i in seq 9 doif [ $i -eq 5 ] ; thenbreakelseecho $ifi done [rootopenEuler ~]# bash break.sh 1 2 3 4 2 c…

Selenium的百度高级搜索-自动化(未完成)

from selenium import webdriver from selenium.webdriver import ActionChainsdriver webdriver.Chrome() driver.implicitly_wait(10) driver.maximize_window() driver.get("https://www.baidu.com/")# 鼠标悬停(难点) setting driver.find_element_by_id("…

【NPS】微软NPS配置802.1x,验证域账号,动态分配VLAN(WLC篇)

距离上一篇【NPS】微软NPS配置802.1x&#xff0c;验证域账号&#xff0c;动态分配VLAN&#xff08;NPS篇&#xff09;已经过去了近两周了&#xff0c;因为工作原因一直没有来得及更新在WLC上的设置&#xff0c;接下来我们来看一下如何在 Cisco Catalyst 9800-L Wireless Contro…

mysql实战——xtrabackup问题

备份恢复后启动不成功。 我测试了很多遍&#xff0c;最开始我以为备份后的数据文件没有pid造成的&#xff0c;所以一直测试 后来发现上图这样是正常的&#xff0c;mysqld_safe后就出现pid和sock文件 那启动失败的原因我认为是权限的问题&#xff0c;把数据文件目录权限全部设置…

golang websocket 发送消息莫名其妙断开的问题记录

概述 公司需要做个B/S架构的前端展示项目&#xff0c;当前以为是小case&#xff0c;但是在实现后端功能的时候&#xff0c;还是被坑了。 功能描述 项目需要实现的功能是调用外部第三方程序&#xff0c; 实时读取第三方程序的输出&#xff0c;发送到前端展示。因为懒得切换平…

使用Django框架搭建Web应用

文章目录 简介安装Django创建一个Django项目创建一个Django应用编写视图配置URL运行开发服务器总结与拓展数据库集成管理后台表单处理模板引擎安全性 简介 Django 是一款基于 Python 语言的开源 Web 应用框架&#xff0c;采用了 MVC&#xff08;模型-视图-控制器&#xff09;设…