描述:給一棵二叉樹,找出從根節點到葉子節點的所有路徑。
樣例:給出下面這棵二叉樹:
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 兩個字串使用 連線...