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

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

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
        '''

全部评论

相关推荐

昨天 00:55
门头沟学院
区域赛银,邀请赛金,打算十二月打下Java基础、背点八股、写个外卖后去投福建小厂的寒假实习,简历应该怎么写呢?以及福州/和厦门有推荐的小厂吗?
牛客53210502...:简历一页:把区域银,邀请赛金标粗,其他的奖除非凑一页否则没有必要写。或者多页:每个站一行这样都列出来。项目经历看看牛客其他人是怎么写的,写的不好呢。简历打磨好按部就班没问题的
点赞 评论 收藏
分享
gelmanspar...:奖学金删掉,自我评价删掉,简历压缩一下,写一页
如果再来一次,你还会学机...
点赞 评论 收藏
分享
10-13 12:53
已编辑
湖北工业大学 前端工程师
小海c:包装一下,第一个感觉是字节青训营的那个,后面那个是黑马的
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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