国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術(shù)文章
文章詳情頁

算法 - 如何不用遞歸 列出 樹(多叉) 中根節(jié)點到葉節(jié)點的所有路徑(Java)

瀏覽:91日期:2024-01-16 11:33:25

問題描述

比如,對于下面這個二叉樹,它所有的路徑為:

8 -> 3 -> 1

8 -> 2 -> 6 -> 4

8 -> 3 -> 6 -> 7

8 -> 10 -> 14 -> 13

算法 - 如何不用遞歸 列出 樹(多叉) 中根節(jié)點到葉節(jié)點的所有路徑(Java)

怎么用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é)點后輸出。

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 久久中文字幕久久久久91 | 91久久国产成人免费观看资源 | 亚州毛片 | 最新国产午夜精品视频成人 | 欧美搞黄视频 | 女人张开腿给男人桶爽免费 | 伊人久久国产免费观看视频 | 成人毛片免费 | 国产精品欧美亚洲韩国日本 | 亚洲一区二区三区在线播放 | 欧美高清免费精品国产自 | 国产一区二区三区亚洲欧美 | 免费永久观看美女视频网站网址 | 国产日韩一区二区三区在线播放 | 欧日韩美香蕉在线观看 | 成人午夜毛片 | 国产美女一区二区三区 | 久久99九九99九九精品 | 久久久久欧美情爱精品 | 成年人视频网站免费 | 欧美性猛片xxxxⅹ免费 | 亚洲精品一区二区三区在线看 | 美女视频黄.免费网址 | 国产成 人 综合 亚洲绿色 | 亚洲精品免费网站 | 在线观看国产 | 国产精品一级片 | 日本人一级毛片视频 | 精品国产三级a∨在线观看 精品国产三级a在线观看 | 日韩一区二区三区不卡视频 | 国产精品免费一区二区三区 | 玖玖在线国产精品 | 一本三道a无线码一区v小说 | 欧美日韩免费一区二区在线观看 | 国产精品一区二区三区久久 | 小明台湾成人永久免费看看 | 久久免费看 | 宅男噜噜噜一区二区三区 | 成年网站视频在线观看 | 在线日韩欧美 | 澳门毛片在线播放 |