算法 - 如何不用遞歸 列出 樹(多叉) 中根節點到葉節點的所有路徑(Java)
問題描述
比如,對于下面這個二叉樹,它所有的路徑為:
8 -> 3 -> 1
8 -> 2 -> 6 -> 4
8 -> 3 -> 6 -> 7
8 -> 10 -> 14 -> 13
怎么用Java去實現?
問題解答
回答1:不用遞歸的話,那就深度優先啦!采用棧, 首先將根結點壓入棧,如果棧不為空,而后出棧并輸出當前結點中值,而后先把右子樹壓入棧,再把左子樹壓入棧,再判斷棧是否為空,循環.....步驟如下:1) 先把二叉樹的根結點入棧2)判斷棧是否為空,不為空,則出棧,并輸出出棧樹結點的值3)出棧樹結點的右子樹入棧4)出棧樹結點的左子樹入棧5)循環回到(2)這是我之前看到的一個方法,不知道能不能幫到題主?
public void depthOrderTraversal(){ if(root==null){ System.out.println('empty tree'); return; } ArrayDeque<TreeNode> stack=new ArrayDeque<TreeNode>(); stack.push(root); while(stack.isEmpty()==false){ TreeNode node=stack.pop(); System.out.print(node.value+' '); if(node.right!=null){ stack.push(node.right); } if(node.left!=null){ stack.push(node.left); } } System.out.print('n'); } 回答2:
用棧替代遞歸:https://zh.coursera.org/learn...
回答3:深度優先?。。
回答4:使用廣度優先遍歷,然后狀態中儲存該節點的所有父節點,到葉子節點后輸出。
相關文章:
1. android - NavigationView 的側滑菜單中如何保存新增項(通過程序添加)2. angular.js - angular做點擊購買時的遮罩層3. 請問這位老師的PHPSTORM主題是自定義的嗎4. 冒昧問一下,我這php代碼哪里出錯了???5. 關于thinkphp 5.1中,ajax提交數據url的格式寫法,加花括號就出錯,請老師指點6. 老師 我是一個沒有學過php語言的準畢業生 我希望您能幫我一下7. 請教!!!本地laravel項目我想本地運行,怎么在本地訪問控制器里的方法。8. 連續的數值怎么用分組顯示,求大神指導,求各位老師幫忙9. 有大佬知道這種接口文件怎么使用嗎?10. AirPods Pro 2連接Pixel 7出問題:播放90秒自動斷連
