1. 程式人生 > >二叉樹中和為某一值的路徑(Java)

二叉樹中和為某一值的路徑(Java)

題目:

輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。二叉樹結點的定義如下:

struct BinaryTreeNode{
	int m_nValue;
	BinaryTreeNode* m_pLeft;
	BinaryTreeNode* m_pRight;
}

思路:

先說一個具體的例子,輸入下圖的二叉樹和整數22,則打印出兩條路徑,第一條路徑包含結點10、12,第二條路徑包含結點10、5和7。



上面的圖具體的分析了這個示例。當用前序遍歷的方式訪問到某一結點時,我們把該結點新增到路徑上,並累加該結點的值。如果該結點為葉結點並且路徑中結點值的和剛好等於輸入的整數,則當前的路徑符合要求,我們把它打印出來。如果當前結點不是葉結點,則繼續訪問它的子結點。當前結點訪問結束後,遞迴函式將自動回到它的父結點。因此我們在函式退出之前要在路徑上刪除當前結點並減去當前結點的值,以確保返回父結點時路徑剛好是從根節點到父結點的路徑。從分析中得知我們需要藉助棧來儲存路徑的資料。

程式碼實現:

public ArrayList<ArrayList<Integer>> findPath(BinaryTreeNode pRoot, int expectedSum){
	ArrayList<ArrayList<Integer>> pathList = new ArrayList<ArrayList<Integer>>();
	if(pRoot == null){ //如果此樹為空則直接返回
		return null;
	}
	Stack<Integer> path = new Stack<Integer>();//定義棧來儲存一條路徑
	findPath(pRoot, expectedSum, path, pathList); //呼叫查詢方法
 	return pathList;
}
private void findPath(BinaryTreeNode pRoot, int expectedSum,
		Stack<Integer> path, ArrayList<ArrayList<Integer>> pathList) {
	if(pRoot == null){
		return;
	}
	//判斷其是不是葉子結點,如果是看其是不是等於期望值,是的話直接新增到ArrayList集合當中
	if(pRoot.leftNode == null && pRoot.rightNode == null){
		if(pRoot.value == expectedSum){ //如果等於期望值,則新增到list集合中
			ArrayList<Integer> list = new ArrayList<Integer>();
			for (int value : path) { //將路徑上的值新增集合中
				list.add(value);
			}
			list.add(pRoot.value);//將根節點值新增入集合
			pathList.add(list); //將這條路徑新增到pathList集合中
		}
	}else{
		//不是葉子結點,前序遍歷,將當前結點值放入path棧中
		path.push(pRoot.value);
		findPath(pRoot.leftNode, expectedSum - pRoot.value, path, pathList);
		findPath(pRoot.rightNode, expectedSum - pRoot.value, path, pathList);
		//在返回到父結點之前,在路徑上刪除當前結點的值
		path.pop();
	}
}

小結:

有時候思路想不到時,就多舉舉例子。有時候有了思路,程式碼實現不了時,多學學基礎與敲敲程式碼。這個題目考查樹的先序遍歷與棧的進出棧結合的題目。

相關推薦

中和的所有路徑

說明 util ray 如果 tree 二叉樹 節點 integer fin 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 import java.util.ArrayList

24、劍指offer--中和路徑

val 遍歷 描述 所有 oid res bold eno bsp 題目描述 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 解題思路:本題采用先序遍歷,遍歷到葉子節點,如果和

中和路徑

one 結點 col val exp fff return back 節點 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 思路:深搜(DFS) struct TreeN

劍指offer十四之中和路徑

rgs one main java http ring dal offer for 一、題目   輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 二、思路 詳見代碼 三、

劍指Offer——中和路徑

roo int paths struct () node nod cnblogs ret 題目描述: 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 分析: 先序遍歷二叉樹,找到

劍指offer-25.中和路徑

path val tmp aux node ptr body 深度 light 0 題目 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 1 分析 深度優先遍歷+回溯. 出點就是,

python劍指offer系列中和路徑

not 和為某一值的路徑 python 數組長度 self. expect pytho def lis 題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(註意:

劍指offer---中和路徑

題目:二叉樹中和為某一值的路徑 要求:輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 1 /* 2 struct TreeNode { 3 int val; 4 struct

中和路徑 python

  輸入一顆二叉樹的根節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。   分析:我們可以先從最簡單的情況開始考慮,最簡單的情況就是二叉樹只有一個根節點,判斷根節點的值與期望值是否相同就ok了。二叉樹稍微複雜一點就是根節點還有

劍指offer系列(十) 中和路徑,複雜連結串列的複製,

二叉樹中和為某一值的路徑 題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 解題思路: 深度優先遞迴遍歷樹, 把結點加入

[劍指offer] --25.中和路徑

題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。 路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 解題思路 每次先把開始的頭結點儲存,然後使用輸入的路

六:中和路徑

/** * 題目:二叉樹中和為某一值的路徑 * 描述:   輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。 *   路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑 * 方案: 

《劍指offer》系列 中和路徑Java

連結 牛客: 二叉樹中和為某一值的路徑 題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 思路 題目給定

【劍指offer】中和路徑【python】

題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 思路: 暴力遍歷二叉樹每一個節點,採用遞歸回溯的思想。建立一個全域性的re

12 中和路徑

0 引言 題目:輸入一顆二叉樹的根節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 1 抽象問題具體化 舉例1:樹的形態如圖所示。給定的整數值為22,求路徑。

劍指offer學習筆記Python--中和路徑

題目描述 輸入一顆二叉樹和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。 思路 可以按照深度優先遍歷(DFS)來處理。建立一個空列表用來存放最終結果。從根節點開始,判斷該節點的值與給定數值是否

劍指Offer-34 中和路徑

題目: 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 解答: # -*- coding:utf-8 -*- # class

劍指offer中和路徑

時間限制:1秒 空間限制:32768K 熱度指數:262145 題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 思

劍指offer-24:中和路徑

題目描述 輸入一顆二叉樹的根節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 思路 dfs演算法 程式碼 public class So

劍指offe題解(中和路徑

題目描述 輸入一顆二叉樹的跟節點和一個整數,打印出二叉樹中結點值的和為輸入整數的所有路徑。路徑定義為從樹的根結點開始往下一直到葉結點所經過的結點形成一條路徑。(注意: 在返回值的list中,陣列長度大的陣列靠前) 思路 遞迴求解,如果根節點不為空,將根節點的值放入vector陣列,如果此