午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

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

問(wèn)題描述

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

8 -> 3 -> 1

8 -> 2 -> 6 -> 4

8 -> 3 -> 6 -> 7

8 -> 10 -> 14 -> 13

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

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

標(biāo)簽: java
相關(guān)文章:
主站蜘蛛池模板: 国产欧美大片 | 91久久国产 | 99精品欧美一区二区三区综合在线 | 三级黄色片 | 成人免费午夜视频 | 成人精品福利 | 中文字幕激情 | 中文字幕日日夜夜 | 四虎影院在线播放 | 久久在线观看视频 | 成人在线激情视频 | 亚洲资源网站 | av一道本 | 色99999| 亚洲综合久久av一区二区三区 | 国产精品久久久网站 | 国产精品二区三区 | 精品久久久久久中文字幕 | 黄色福利网站 | 九九视频免费观看 | 国产剧情av在线播放 | 青青草成人网 | 精品婷婷 | 色午夜av | 午夜在线看 | 国产精品美女www | 久久精品福利视频 | 97人人艹 | 日韩精品视频网站 | 91首页| 国产成人精品一区二区三区 | 午夜激情免费视频 | 91视频在线网站 | 国产在线无 | 成人免费毛片入口 | 肢体的诱惑在线观看 | 亚洲第一免费视频 | 色婷婷国产精品综合在线观看 | www.99re7| 日韩色网站| 成人国产精品久久久网站 |