leetcode 路徑總和II(python)

2021-09-13 12:37:00 字數 943 閱讀 9731

題目:

給定乙個二叉樹和乙個目標和,找到所有從根節點到葉子節點路徑總和等於給定目標和的路徑。

說明: 葉子節點是指沒有子節點的節點。

示例:給定如下二叉樹,以及目標和 sum = 22,

5

/ \4 8

/ / \

11 13 4

/ \ / \

7 2 5 1

返回:

[[5,4,11,2],

[5,8,4,5]

]思想:

二叉樹深度遍歷+回溯

**:

class solution:

def pathsum(self, root: treenode, sum: int) -> list[list[int]]:

pathvalue=0

path=

result=

def preorder(node,pathvalue,sum,path,result):

if node==none:

return

pathvalue+=node.val

if pathvalue==sum and node.left==none and node.right==none:

preorder(node.left,pathvalue,sum,path,result)

preorder(node.right,pathvalue,sum,path,result)

pathvalue-=node.val

path.pop()

preorder(root,pathvalue,sum,path,result)

return result

LeetCode 路徑總和

給定乙個二叉樹和乙個目標和,判斷該樹中是否存在根節點到葉子節點的路徑,這條路徑上所有節點值相加等於目標和。說明 葉子節點是指沒有子節點的節點。示例 給定如下二叉樹,以及目標和 sum 22,5 4 8 11 13 4 7 2 1 如下 definition for a binary tree nod...

LeetCode 路徑總和

給定乙個二叉樹,它的每個結點都存放著乙個整數值。找出路徑和等於給定數值的路徑總數。路徑不需要從根節點開始,也不需要在葉子節點結束,但是路徑方向必須是向下的 只能從父節點到子節點 二叉樹不超過1000個節點,且節點數值範圍是 1000000,1000000 的整數。示例 root 10,5,3,3,2...

LeetCode 路徑總和III

給定乙個二叉樹,它的每個結點都存放著乙個整數值。找出路徑和等於給定數值的路徑總數。路徑不需要從根節點開始,也不需要在葉子節點結束,但是路徑方向必須是向下的 只能從父節點到子節點 二叉樹不超過1000個節點,且節點數值範圍是 1000000,1000000 的整數。示例 root 10,5,3,3,2...