【剑指offer】034.二叉树中和为某一值的路径

本文解析了如何使用深度优先搜索(DFS)解决LeetCode《剑指Offer》中的第034题,重点在于理解Python中可变对象与不可变对象的传递差异,以及如何在DFS过程中正确处理路径结果。通过实例代码演示了如何找到二叉树中和为特定值的所有路径。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目

【剑指offer】034.二叉树中和为某一值的路径

解法

DFS。但是这里要注意python的一些特性。
python传参传对象,可变对象可变,不可变对象不可变

class Solution:
    def pathSum(self, root: TreeNode, target: int) -> List[List[int]]:
        res, cur = [], []
        def dfs(root, tar):
            if not root: return 
            cur.append(root.val)
            if root.left is None and root.right is None and root.val==tar:
                res.append(list(cur)) # 这个域里,要用list()将cur转成值,不然,cur是一个可变对象,后面cur变化,res也会变
            else:
                dfs(root.left, tar-root.val)
                dfs(root.right, tar-root.val)
            cur.pop(-1)
        dfs(root, target)
        return res
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值