輸入一棵二叉樹和乙個整數,列印出二叉樹中節點值的和為輸入整數的所有路徑
從樹的根節點開始往下一直到葉節點所經過的節點形成一條路徑
用乙個棧儲存經過的路徑, 乙個臨時變數儲存當前的和
遍歷乙個節點時, 將該節點壓入棧, 並取出值加到臨時變數
當遍歷到葉節點時, 判斷臨時變數是否等於指定值, 是則將棧作為整體加入結果集
class
solution
public
void
path
(treenode root,
int tmp)
tmp -= root.val;
stack.
add(root.val)
;// 如果是葉子節點
if(tmp ==
0&& root.left == null && root.right == null)
path
(root.left, tmp)
;path
(root.right, tmp)
; stack.
removelast()
;}}
劍指Offer 34 二叉樹中和為某一值的路徑
題目描述 輸入一顆二叉樹和乙個整數,列印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。struct treenode class solution void dfs treenode root,int s,vector ret,vect...
劍指Offer 34 二叉樹中和為某一值的路徑
輸入一棵二叉樹和乙個整數,列印出二叉樹中節點值的和為輸入整數的所有路徑。從樹的根節點開始往下一直到葉節點所經過的節點形成一條路徑。例 給定如下二叉樹,以及目標和 sum 22,5 4 8 11 13 4 7 2 5 1返回 5,4,11,2 5,8,4,5 思路很明確,深度優先搜尋sum node ...
劍指Offer 34 二叉樹中和為某一值的路徑
20.5.3 最佳寫法 注意不要在新增了一條路徑後直接返回,任何乙個節點返回時都要從路徑中pop出去 class solution void dfs treenode root,int sum if root left dfs root left,sum if root right dfs root...