
【python-leetcode113-树的深度遍历】路径总和Ⅱ
发布日期:2021-05-09 08:30:44
浏览次数:17
分类:博客文章
本文共 1561 字,大约阅读时间需要 5 分钟。
对应着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()
发表评论
最新留言
初次前来,多多关照!
[***.217.46.12]2025年04月29日 09时09分18秒
关于作者

喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!
推荐文章
52. 什么时候会发生类初始化?
2019-03-09
JavaScript——使用iterator遍历迭代map,set集合元素
2019-03-09
常用的Linux命令
2019-03-09
STM32外设使用(四) ADC
2019-03-10
Keil 查看文件路径的方法
2019-03-10
Risc-V 内核
2019-03-10
IAR调试卡顿的解决办法
2019-03-10
应用程序无法启动,应用程序的并行配置不正确完美解决方法
2019-03-10
【IntelliJ IDEA 2019.2】idea如何开启自动编译
2019-03-10
【Android Studio 3.5.3】安卓与单片机进行usb hid通信
2019-03-10
使用MovieMator Video Editor Pro在视频中添加图像叠加层
2019-03-10
强大的文字处理器——Nisus Writer Pro
2019-03-10
如何轻松适应从Windows到MacOS的过渡!Mac新手入门指南
2019-03-10
Mac入门指南技巧:如何查找隐藏文件!怎样设置搜索条件!
2019-03-10
fcpx插件:25个假日主题专业设计
2019-03-10
fcpx插件:Block Party for Mac(53个视频转场插件)
2019-03-10
Mac使用技巧:快速视频播放错误如何修护
2019-03-10
代码绘制五角形
2019-03-10
Course Schedule II
2019-03-10