python简单算法题_关于二叉树的一道简单算法题,结果很诡异(python)

lintcode原题:

二叉树的路径和

给定一个二叉树,找出所有路径中各节点相加总和等于给定 目标值 的路径。

一个有效的路径,指的是从根节点到叶节点的路径。

我的解答

"""

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

result=[]

path=[]

self.dfs(root,path,result,target)

return result

def dfs(self,root,path,result,target):

if root is None:

return

path.append(root.val)

if root.left is None and root.right is None and sum(path)==target:

result.append(path)

if root.left:

self.dfs(root.left,path,result,target)

if root.right:

self.dfs(root.right,path,result,target)

path.pop()

结果总是错误

输入

{1,2,4,2,3}

5

输出

[[],[]]

期望答案

[[1,2,2],[1,4]]

我实在想不通为什么答案是空,后来我意识到可能是传参数的问题,改成如下代码:

if root.left is None and root.right is None and sum(path)==target:

result.append(path+[])

这里只改了中间那一行,将path改为path+[],居然华丽丽的成功了,实在是想不通为什么,有人指点一二吗?谢了!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值