【python-leetcode113-树的深度遍历】路径总和Ⅱ
时间:2022-07-23
本文章向大家介绍【python-leetcode113-树的深度遍历】路径总和Ⅱ,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
对应着lintcode376题。
给定一个二叉树,找出所有路径中各节点相加总和等于给定 目标值 的路径。
一个有效的路径,指的是从根节点到叶节点的路径。
样例 样例1:
输入: {1,2,4,2,3} 5 输出: [[1, 2, 2],[1, 4]] 说明: 这棵树如下图所示: 1 / 2 4 / 2 3 对于目标总和为5,很显然1 + 2 + 2 = 1 + 4 = 5 样例2:
输入: {1,2,4,2,3} 3 输出: [] 说明: 这棵树如下图所示: 1 / 2 4 / 2 3 注意到题目要求我们寻找从根节点到叶子节点的路径。 1 + 2 + 2 = 5, 1 + 2 + 3 = 6, 1 + 4 = 5 这里没有合法的路径满足和等于3.
"""
Definition of TreeNode:
class TreeNode:
def __init__(self, val):
self.val = val
self.left, self.right = None, None
"""
class Solution:
"""
@param: root: the root of binary tree
@param: target: An integer
@return: all valid paths
"""
def binaryTreePathSum(self, root, target):
# write your code here
global res
#保存结果
res=[]
#临时数组
tmp=[]
self.pathSum(res,tmp,root,target)
return res
def pathSum(self,res,tmp,root,target):
if root == None:
return
#首先将当前节点的值加入到tmp中
tmp.append(root.val)
#如果当前节点没有左右孩子,说明是叶子节点
if root.left == None and root.right == None:
#计算根节点到叶子节点的值
s = sum(tmp)
#如果该值等于target
if s == target:
#这里需要拷贝一份tmp,再加入到结果中
newtmp=tmp[:]
res.append(newtmp)
#如果有左孩子
if root.left!=None:
self.pathSum(res,tmp,root.left,target)
#如果遍历到叶子节点了,且不符合sum(tmp)==target,则最后面的节点出栈
tmp.pop()
#如果有右孩子
if root.right!=None:
self.pathSum(res,tmp,root.right,target)
#如果遍历到叶子节点了,且不符合sum(tmp)==target,则最后面的节点出栈
tmp.pop()
- Wordpress <= 4.6.1 使用主题文件触发存储型XSS 漏洞分析
- 如何跨平台在本地开发环境提交MapReduce作业到CDH集群
- 区块链行业的机会
- KEGG数据库的rest API(附带R语言小技巧)
- 如何使用Java代码访问HDFS.docx
- Django CSRF Bypass (CVE-2016-7401) 漏洞分析
- 如何使用Cloudera Manager禁用YARN的HA
- Web Worker 中的 importScripts 和 baseHref 同源策略绕过问题
- 如何使用Java代码访问CDH的Solr服务
- Safari UXSS漏洞分析(CVE-2016-4758)
- Sqoop抽取Hive Parquet表数据到MySQL异常分析
- Hue中使用Oozie创建Ssh工作流时sudo命令执行失败问题分析
- [译]Safari URL重定向漏洞(CVE-2016-4585)利用分析
- Hive中的Timestamp类型日期与Impala中显示不一致分析(补充)
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 【Android 音频】“声音”从何而来
- 你知道怎么攻击RMI吗?
- 腾讯云 Serverless 支撑「新东方」核心业务算力资源
- R代码|基于特征重要性的特征排序代码
- windows-exploit-suggester使用指导
- lcx实现端口转发
- 支付宝二维码脱机认证库测试过程记录(andorid平台adb shell验证)
- R代码|dplyr包的使用示例
- ES 面试题
- 支付宝二维码脱机认证库在android的app下测试过程记录
- 在?进来看看怎么攻击JMX呗
- mysql 中的锁结构
- 我的小工具-远程读卡器web客户端(PHP+LUA)
- Linux下suid提权利用
- scala 类型 的最详细解释