算法 - 如何不用遞歸 列出 樹(shù)(多叉) 中根節(jié)點(diǎn)到葉節(jié)點(diǎn)的所有路徑(Java)
問(wèn)題描述
比如,對(duì)于下面這個(gè)二叉樹(shù),它所有的路徑為:
8 -> 3 -> 1
8 -> 2 -> 6 -> 4
8 -> 3 -> 6 -> 7
8 -> 10 -> 14 -> 13

怎么用Java去實(shí)現(xiàn)?
問(wèn)題解答
回答1:不用遞歸的話(huà),那就深度優(yōu)先啦!采用棧, 首先將根結(jié)點(diǎn)壓入棧,如果棧不為空,而后出棧并輸出當(dāng)前結(jié)點(diǎn)中值,而后先把右子樹(shù)壓入棧,再把左子樹(shù)壓入棧,再判斷棧是否為空,循環(huán).....步驟如下:1) 先把二叉樹(shù)的根結(jié)點(diǎn)入棧2)判斷棧是否為空,不為空,則出棧,并輸出出棧樹(shù)結(jié)點(diǎn)的值3)出棧樹(shù)結(jié)點(diǎn)的右子樹(shù)入棧4)出棧樹(shù)結(jié)點(diǎn)的左子樹(shù)入棧5)循環(huán)回到(2)這是我之前看到的一個(gè)方法,不知道能不能幫到題主?
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)中儲(chǔ)存該節(jié)點(diǎn)的所有父節(jié)點(diǎn),到葉子節(jié)點(diǎn)后輸出。
相關(guān)文章:
1. boot2docker無(wú)法啟動(dòng)2. docker-compose中volumes的問(wèn)題3. 關(guān)docker hub上有些鏡像的tag被標(biāo)記““This image has vulnerabilities””4. docker容器呢SSH為什么連不通呢?5. java - SSH框架中寫(xiě)分頁(yè)時(shí)service層中不能注入分頁(yè)類(lèi)6. dockerfile - 為什么docker容器啟動(dòng)不了?7. 關(guān)于docker下的nginx壓力測(cè)試8. node.js - antdesign怎么集合react-redux對(duì)input控件進(jìn)行初始化賦值9. docker安裝后出現(xiàn)Cannot connect to the Docker daemon.10. nignx - docker內(nèi)nginx 80端口被占用

網(wǎng)公網(wǎng)安備