成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

每日算法:二叉樹的層次遍歷

開發(fā) 開發(fā)工具 算法
給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值自底向上的層次遍歷。(即按從葉子節(jié)點(diǎn)所在層到根節(jié)點(diǎn)所在的層,逐層從左向右遍歷)。

[[423982]]

給定一個(gè)二叉樹,返回其節(jié)點(diǎn)值自底向上的層次遍歷。(即按從葉子節(jié)點(diǎn)所在層到根節(jié)點(diǎn)所在的層,逐層從左向右遍歷)

例如:給定二叉樹 [3,9,20,null,null,15,7] ,

3

/ \

9 20

/ \

15 7

返回其自底向上的層次遍歷為:

  1.   [15,7], 
  2.   [9,20], 
  3.   [3] 

解法一:BFS(廣度優(yōu)先遍歷)

BFS 是按層層推進(jìn)的方式,遍歷每一層的節(jié)點(diǎn)。題目要求的是返回每一層的節(jié)點(diǎn)值,所以這題用 BFS 來做非常合適。BFS 需要用隊(duì)列作為輔助結(jié)構(gòu),我們先將根節(jié)點(diǎn)放到隊(duì)列中,然后不斷遍歷隊(duì)列。

  1. const levelOrderBottom = function(root) { 
  2.     if(!root) return [] 
  3.     let res = [],  
  4.         queue = [root] 
  5.     while(queue.length) { 
  6.         let curr = [], 
  7.             temp = [] 
  8.         while(queue.length) { 
  9.             let node = queue.shift() 
  10.             curr.push(node.val) 
  11.             if(node.lefttemp.push(node.left
  12.             if(node.righttemp.push(node.right
  13.         } 
  14.         res.push(curr) 
  15.         queue = temp 
  16.     } 
  17.     return res.reverse() 
  18. }; 

復(fù)雜度分析

  • 時(shí)間復(fù)雜度:O(n)
  • 空間復(fù)雜度:O(n)

解法二:DFS(深度優(yōu)先遍歷)

DFS 是沿著樹的深度遍歷樹的節(jié)點(diǎn),盡可能深地搜索樹的分支

DFS 做本題的主要問題是:DFS 不是按照層次遍歷的。為了讓遞歸的過程中同一層的節(jié)點(diǎn)放到同一個(gè)列表中,在遞歸時(shí)要記錄每個(gè)節(jié)點(diǎn)的深度 depth 。遞歸到新節(jié)點(diǎn)要把該節(jié)點(diǎn)放入 depth 對(duì)應(yīng)列表的末尾。

當(dāng)遍歷到一個(gè)新的深度 depth ,而最終結(jié)果 res 中還沒有創(chuàng)建 depth 對(duì)應(yīng)的列表時(shí),應(yīng)該在 res 中新建一個(gè)列表用來保存該 depth 的所有節(jié)點(diǎn)。

  1. const levelOrderBottom = function(root) { 
  2.     const res = [] 
  3.     var dep = function (node, depth){ 
  4.         if(!node) return 
  5.         res[depth] = res[depth]||[] 
  6.         res[depth].push(node.val) 
  7.         dep(node.left, depth + 1) 
  8.         dep(node.right, depth + 1) 
  9.     } 
  10.     dep(root, 0) 
  11.     return res.reverse()    
  12. }; 

復(fù)雜度分析:

 

  • 時(shí)間復(fù)雜度:O(n)
  • 空間復(fù)雜度:O(h),h為樹的高度

 

責(zé)任編輯:武曉燕 來源: 三分鐘學(xué)前端
相關(guān)推薦

2021-09-29 10:19:00

算法平衡二叉樹

2020-04-27 07:05:58

二叉樹左子樹右子樹

2021-01-13 10:03:36

二叉樹層序遍歷層次遍歷

2021-09-28 06:28:51

二叉樹公共祖先

2022-10-26 23:58:02

二叉樹數(shù)組算法

2009-08-11 13:29:57

C#二叉樹遍歷

2021-04-20 08:37:14

數(shù)據(jù)結(jié)構(gòu)二叉樹

2023-05-08 15:57:16

二叉樹數(shù)據(jù)結(jié)構(gòu)

2013-07-15 16:35:55

二叉樹迭代器

2020-09-23 18:25:40

算法二叉樹多叉樹

2021-09-15 07:40:50

二叉樹數(shù)據(jù)結(jié)構(gòu)算法

2020-12-22 08:56:51

JavaScript數(shù)據(jù)結(jié)構(gòu)前端

2021-04-19 07:47:42

數(shù)據(jù)結(jié)構(gòu)二叉樹Tree

2021-07-13 11:32:41

二叉樹數(shù)據(jù)結(jié)構(gòu)算法

2021-04-28 20:12:27

數(shù)據(jù)結(jié)構(gòu)創(chuàng)建

2024-01-23 12:54:00

C++編程語言代碼

2021-08-27 11:36:44

二叉樹回溯節(jié)點(diǎn)

2020-12-30 08:35:34

貪心算法監(jiān)控

2021-03-17 08:19:22

二叉樹LeetCode

2021-03-22 08:23:29

LeetCode二叉樹節(jié)點(diǎn)
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 国产成人av一区二区三区 | 一区二区成人 | 四虎成人在线播放 | 成人在线免费电影 | 国产亚洲高清视频 | 亚洲精品9999久久久久 | 91精品国产欧美一区二区成人 | 亚洲综合视频 | 欧美在线视频一区 | 久久毛片 | 99热在线观看精品 | 国产一伦一伦一伦 | 草草草久久久 | 日韩a在线| 日本久久精品 | 精品成人 | 中文字幕在线视频免费视频 | 国产精品久久久久久吹潮 | av激情在线 | av中文字幕在线播放 | 国产精品视频一区二区三区 | 色视频一区二区 | 中文字幕精品一区 | 日韩精品一区二区在线 | 精品一区国产 | 99国产精品久久久 | 精品欧美一区二区三区久久久 | 欧美日韩福利视频 | 日本激情一区二区 | 中文字幕av免费 | 中文字幕国产视频 | www.玖玖玖 | 欧美性一级 | 青青久久 | 国产精品一区二区三区四区 | 国产精品免费视频一区 | 超碰97av | 国产日产久久高清欧美一区 | 国内自拍视频在线观看 | 国产极品车模吞精高潮呻吟 | 91porn在线|