当前位置: 首页 > article >正文

力扣刷题第二十六天--二叉树

前言

昨天看总决赛,差距太大,看的没意思,真的是一点变通没有啊。难受,没有写题的状态了。大概率是最后一次看比赛了,青春已复过,白日忽相催。召唤师要和生活对线了。英雄们的语音,台词,技能历历在目,再多不舍,也要说再见。Legends never die!调整状态,再出发!再高的山,再长的河,也会越过!

层序遍历的模板基本上就是这样,掌握好。

内容

一、二叉树的层序遍历

102.二叉树的层序遍历

给你二叉树的根节点 root ,返回其节点值的 层序遍历 。 (即逐层地,从左到右访问所有节点)。

本题为后端高频面试题,被收录于《热招技术岗上岸指南》

广度优先搜素

层序遍历方式就是图论中的广度优先遍历,只不过我们应用在二叉树上

/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
 //用切片模拟队列
func levelOrder(root *TreeNode) [][]int {
   var  res [][]int
   if root==nil{
       return res
   }
   curLevel:=[]*TreeNode{root}// 存放当前层节点
   for len(curLevel)>0{
       nextLevel:=[]*TreeNode{}// 准备通过当前层生成下一层
       vals:=[]int{}

       for _,node:=range curLevel{
           vals=append(vals,node.Val)// 收集当前层的值
           if node.Left!=nil{ // 收集下一层的节点
               nextLevel=append(nextLevel,node.Left)
           }
           if node.Right!=nil{
               nextLevel=append(nextLevel,node.Right)
           }
       }
       res=append(res,vals)
       curLevel=nextLevel// 将下一层变成当前层
   }
   return res
}
二、 二叉树的层序遍历II

107.二叉树的层序遍历II

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

广度优先搜素

上一题反转一下结果集即可

/**
 * Definition for a binary tree node.
 * type TreeNode struct {
 *     Val int
 *     Left *TreeNode
 *     Right *TreeNode
 * }
 */
func levelOrderBottom(root *TreeNode) [][]int {
     var res [][]int
     if root==nil{
         return res
     }
     curLevel:=[]*TreeNode{root}
     for len(curLevel)>0{
         nextLevel:=[]*TreeNode{}
         vals:=[]int{}
         for _,node:=range curLevel{
             vals=append(vals,node.Val)
             if node.Left!=nil{
                 nextLevel=append(nextLevel,node.Left)
             }
             if node.Right!=nil{
                 nextLevel=append(nextLevel,node.Right)
             }
         }
         res=append(res,vals)
        curLevel=nextLevel
     }
     n:=len(res)
     for i:=0;i<n/2;i++{
         res[i],res[n-1-i]=res[n-1-i],res[i]
     }
     return res
}

最后

为什么有的人总能保持高energy?你却总是消耗energy,导致没有精力做重要的事。内心充盈,精力充沛,才能吸引,影响别人!保护好自己的energy!!!


http://www.kler.cn/a/136953.html

相关文章:

  • 数据库管理-第274期 Oracle Enterprise Manager 24ai新特性一览(20241223)
  • SOTA简繁中文拼写检查工具:FASPell Chinese Spell Checker 论文
  • GitCode 光引计划投稿 | GoIoT:开源分布式物联网开发平台
  • 专栏二十三:Python读取和分析空间数据的经验杂谈
  • 在 Ubuntu 上安装 VS Code
  • 【零基础保姆级教程】制作自己的数据集(二)——Labelme的安装与使用及常见的报错解决方法
  • seleninum 基础及简单实践
  • Unity 中 TextMesh Pro 认识学习
  • 每天分享五款工具,让大家工作生活更顺心
  • xpath
  • 音视频项目—基于FFmpeg和SDL的音视频播放器解析(十五)
  • ISP概念入门
  • java中的接口
  • 如何提⾼webpack的打包速度?
  • 键鼠自动化2.0树形结构讲解
  • [hive] posexplode函数
  • 外贸ERP系统是什么?推荐的外贸管理软件?
  • Keithley2420吉时利2420数字源表
  • Axios七大特性
  • C++: int转换成LPCSTR
  • JVM入门
  • 一份全面「梳理LLM幻觉问题」的综述
  • 生成指定位数强Lucas校验伪素数-Arnault1995构造法
  • pytorch下载离线包的网址
  • Mac如何搭建Vue项目
  • 在ITSM中,实施变更管理的重要因素!