文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

每日算法:二叉树的层次遍历

2024-12-02 21:26

关注

给定一个二叉树,返回其节点值自底向上的层次遍历。(即按从叶子节点所在层到根节点所在的层,逐层从左向右遍历)

例如:给定二叉树 [3,9,20,null,null,15,7] ,

3

/ \

9 20

/ \

15 7

返回其自底向上的层次遍历为:

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

解法一:BFS(广度优先遍历)

BFS 是按层层推进的方式,遍历每一层的节点。题目要求的是返回每一层的节点值,所以这题用 BFS 来做非常合适。BFS 需要用队列作为辅助结构,我们先将根节点放到队列中,然后不断遍历队列。

  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. }; 

复杂度分析

解法二:DFS(深度优先遍历)

DFS 是沿着树的深度遍历树的节点,尽可能深地搜索树的分支

DFS 做本题的主要问题是:DFS 不是按照层次遍历的。为了让递归的过程中同一层的节点放到同一个列表中,在递归时要记录每个节点的深度 depth 。递归到新节点要把该节点放入 depth 对应列表的末尾。

当遍历到一个新的深度 depth ,而最终结果 res 中还没有创建 depth 对应的列表时,应该在 res 中新建一个列表用来保存该 depth 的所有节点。

  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. }; 

复杂度分析:

 

 

来源:三分钟学前端内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯