算法 - 如何不用遞歸 列出 樹(多叉) 中根節(jié)點到葉節(jié)點的所有路徑(Java)
問題描述
比如,對于下面這個二叉樹,它所有的路徑為:
8 -> 3 -> 1
8 -> 2 -> 6 -> 4
8 -> 3 -> 6 -> 7
8 -> 10 -> 14 -> 13
怎么用Java去實現(xiàn)?
問題解答
回答1:不用遞歸的話,那就深度優(yōu)先啦!采用棧, 首先將根結(jié)點壓入棧,如果棧不為空,而后出棧并輸出當(dāng)前結(jié)點中值,而后先把右子樹壓入棧,再把左子樹壓入棧,再判斷棧是否為空,循環(huán).....步驟如下:1) 先把二叉樹的根結(jié)點入棧2)判斷棧是否為空,不為空,則出棧,并輸出出棧樹結(jié)點的值3)出棧樹結(jié)點的右子樹入棧4)出棧樹結(jié)點的左子樹入棧5)循環(huán)回到(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:深度優(yōu)先?。。
回答4:使用廣度優(yōu)先遍歷,然后狀態(tài)中儲存該節(jié)點的所有父節(jié)點,到葉子節(jié)點后輸出。
相關(guān)文章:
1. java - 如何在Fragment中調(diào)用Activity的onNewIntent?2. javascript - js 對中文進(jìn)行MD5加密和python結(jié)果不一樣。3. python - 獲取到的數(shù)據(jù)生成新的mysql表4. mysql里的大表用mycat做水平拆分,是不是要先手動分好,再配置mycat5. javascript - 圖片鏈接請求一直是pending狀態(tài),導(dǎo)致頁面崩潰,怎么解決?6. python的文件讀寫問題?7. javascript - ionic1的插件如何遷移到ionic2的項目中8. window下mysql中文亂碼怎么解決??9. sass - gem install compass 使用淘寶 Ruby 安裝失敗,出現(xiàn) 40410. javascript - jquery hide()方法無效
