亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁技術文章
文章詳情頁

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

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

問題描述

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

8 -> 3 -> 1

8 -> 2 -> 6 -> 4

8 -> 3 -> 6 -> 7

8 -> 10 -> 14 -> 13

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

怎么用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:

使用廣度優先遍歷,然后狀態中儲存該節點的所有父節點,到葉子節點后輸出。

標簽: java
相關文章:
主站蜘蛛池模板: 国产精品久久久久9999赢消 | 国产精品成人在线播放 | 亚洲精品区在线播放一区二区 | 韩国免费毛片在线看 | 伊人黄色 | 亚洲欧美精品成人久久91 | 亚洲在线不卡 | 免费网站在线观看国产v片 免费网站成人亚洲 | 欧美黄色一级视屏 | 国产精品成人h片在线 | free china 麻豆 hd video | 久久久久伊人 | 国产无遮挡色视频免费视频 | 青青视频国产在线播放 | 久久99这里只有精品国产 | 女人被男人狂躁的免费视频 | 一级毛片日本特黄97人人 | 久久夜色精品 | 国产限制级在线 | 免费黄网在线 | 成人精品一区二区久久久 | 成人黄色在线观看 | 精品外国呦系列在线观看 | 免费人成在线视频播放2022 | 国产美女久久久久 | 国内精品一区二区三区 | 香蕉久久精品 | 成人爽a毛片在线视频 | 国内精品视频九九九九 | 精品日韩欧美一区二区三区 | 亚洲毛片免费在线观看 | 国产色婷婷精品综合在线观看 | 日韩性黄色一级 | 国产欧美精品一区二区色综合 | 中文福利视频 | 久久精品综合一区二区三区 | 午夜网站在线观看 | 国产一区二区自拍视频 | 黄色一级片免费 | 国产福利视频一区二区 | 日本免费看片在线播放 |