题解 | #二叉树中和为某一值的路径(一)#

二叉树中和为某一值的路径(一)

https://www.nowcoder.com/practice/508378c0823c423baa723ce448cbfd0c

from enum import Flag
# class TreeNode:
#     def __init__(self, x):
#         self.val = x
#         self.left = None
#         self.right = None
#
# 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可
#
# 
# @param root TreeNode类 
# @param sum int整型 
# @return bool布尔型
#
class Solution:
    def hasPathSum(self , root: TreeNode, s: int) -> bool:
        # write code here
        res = [] # 尝试用更少的空间
        if not root:
            return False
        flag = [False]
        def backtrace(root): # 递归搜索
            res.append(root.val)
            if not root.left and not root.right: # 如果搜到叶子节点
                if sum(res) == s: # 判断和等不等
                    flag=True
                    return
            if root.left:
                backtrace(root.left) # 左递归
                if not flag[0]:
                    res.pop() # 回溯
                else:
                    return
            if root.right:
                backtrace(root.right) # 右递归
                if not flag[0]:
                    res.pop() # 回溯
                else:
                    return

        backtrace(root)
        return flag[0]





        ''' # 以下是两个栈的O(n)复杂度解法
        if not root:
            return False
        from collections import deque
        DQ = deque([root])
        PATH = deque([[root.val]])

        while DQ:
            cur = DQ.popleft()
            cur_path = PATH.popleft()
            if sum(cur_path) == s and not cur.left and not cur.right:
                return True
            if cur.left:
                DQ.append(cur.left)
                PATH.append(cur_path + [cur.left.val])
            if cur.right:
                DQ.append(cur.right)
                PATH.append(cur_path + [cur.right.val])

        return False
        '''

全部评论

相关推荐

点赞 评论 收藏
分享
2025-12-28 16:32
重庆邮电大学 Java
程序员花海:1.技能放最后,来面试默认你都会,技能没啥用 2.实习写的看起来没啥含金量,多读读部门文档,包装下 接LLM这个没含金量 也不要用重构这种 不会给实习生做的 3.抽奖这个还是Demo项目,实际在公司里面要考虑策略,满减,触发点,触发规则 库存 之类的,不是这个项目这么简单 4.教育背景提前,格式为 教育背景 实习 项目 技能 自我评价
简历被挂麻了,求建议
点赞 评论 收藏
分享
ldyllic:飞神,985+美团+腾讯+京东,无敌飞飞神
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务