成人视屏在线观看-国产99精品-国产精品1区2区-欧美一级在线观看-国产一区二区日韩-色九九九

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

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

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

問題描述

比如,對(duì)于下面這個(gè)二叉樹,它所有的路徑為:

8 -> 3 -> 1

8 -> 2 -> 6 -> 4

8 -> 3 -> 6 -> 7

8 -> 10 -> 14 -> 13

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

怎么用Java去實(shí)現(xiàn)?

問題解答

回答1:

不用遞歸的話,那就深度優(yōu)先啦!采用棧, 首先將根結(jié)點(diǎn)壓入棧,如果棧不為空,而后出棧并輸出當(dāng)前結(jié)點(diǎn)中值,而后先把右子樹壓入棧,再把左子樹壓入棧,再判斷棧是否為空,循環(huán).....步驟如下:1) 先把二叉樹的根結(jié)點(diǎn)入棧2)判斷棧是否為空,不為空,則出棧,并輸出出棧樹結(jié)點(diǎn)的值3)出棧樹結(jié)點(diǎn)的右子樹入棧4)出棧樹結(jié)點(diǎn)的左子樹入棧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)后輸出。

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 在线播放亚洲精品 | 国产手机在线国内精品 | 欧美日韩国产人成在线观看 | 亚洲欧美成人在线 | 一个人看的www片免费视频中文 | 欧美一级毛片aaa片 欧美一级毛片不卡免费观看 | 国产情侣无套精品视频 | 国产一区二区中文字幕 | a级毛片在线免费看 | 中文字幕成人在线观看 | xxxxx性欧美| 请看一下欧美一级毛片 | 国产三级网站在线观看 | 真实国产普通话对白乱子子伦视频 | 99精品在免费线视频 | 久久污| 最新国产三级在线观看不卡 | 亚州毛片 | 国产精品亚洲欧美一级久久精品 | 欧美一级va在线视频免费播放 | 国产成人精品亚洲日本语音 | 欧美一级毛片在线看视频 | 亚洲看片 | 日韩久久一区二区三区 | 曰本黄页 | 精品性久久 | 在线综合视频 | 99视频在线免费观看 | 99久久99热精品免费观看国产 | 特级av毛片免费观看 | 天堂精品高清1区2区3区 | 在线播放另类 | 国产午夜免费不卡精品理论片 | 一区二区三区伦理 | 欧美成人精品不卡视频在线观看 | 特黄大片aaaaa毛片 | 亚洲一级毛片在线播放 | 日韩成人毛片高清视频免费看 | 国产精品19p | 中文字幕亚洲综合久久男男 | 三级毛片免费观看 |