二叉樹的所有路徑

2021-07-30 18:59:36 字數 752 閱讀 8196

描述:給一棵二叉樹,找出從根節點到葉子節點的所有路徑。

樣例:給出下面這棵二叉樹:

1/   \

2     3\5

所有根到葉子的路徑為:

["1->2->5",

"1->3"

]解題思路:要找到二叉樹的所有路徑,就相當於從根節點出發一直到葉子節點。我們可以在遍歷的基礎之上完成這項操作,但是又有所不同。首先從根節點出發,先遍歷它的左子樹,直到最左邊的葉子節點,這是一條路徑,然後返回在從根節點開始找起。但是此時跟遍歷不同的是,已經訪問過的節點將不再儲存。具體實現方法可以用遞迴的方法實現。

實現**:

/*** definition of treenode:

* class treenode

* }*/

class solution

void binarytreepathscore(treenode* root,vector&s,string spath)

if(root->left!=null)

binarytreepathscore(root->left,s,spath+"->"+to_string(root->left->val));

if(root->right!=null)

binarytreepathscore(root->right,s,spath+"->"+to_string(root->right->val));}};

做題感想:進一步體會遞迴函式的使用方法。怎樣找到葉子節點然後將乙個路徑儲存起來。

二叉樹的所有路徑

一 問題描述 給一棵二叉樹,找出從根節點到葉子節點的所有路徑。樣例 給出下面這棵二叉樹 1 2 3 5 所有根到葉子的路徑為 1 2 5 1 3 二 解題思路 運用遞迴的思想查詢二叉樹的所有路徑,定義乙個向量用來儲存路徑,然後運用前序遍歷二叉樹,返回查詢的的路徑,在庫檔案string中,to str...

二叉樹的所有路徑

問題描述 給一棵二叉樹,找出從根節點到葉子節點的所有路徑。樣例 給出下面這棵二叉樹 1 2 3 5所有根到葉子的路徑為 1 2 5 1 3 解題思路 若二叉樹不為空,將節點新增到向量中,左右子樹進行遞迴,通過函式呼叫然後輸出。definition of treenode class treenode...

二叉樹的所有路徑

問題描述 給一棵二叉樹,找出從根節點到葉子節點的所有路徑。樣例 給出下面這棵二叉樹 1 2 3 5所有根到葉子的路徑為 1 2 5 1 3 思路 因為返回型別是vector,故需要建立新的函式而且需要將root的val型別轉換為string型別,用到函式to string int 兩個字串使用 連線...