leetcode 102.二叉树的层序遍历

这道题讲的就是对于树的数据结构的考察,这里用了一个比较常用的容器就是队列。

思路:首先我们知道,层序遍历也就是广度优先遍历的一种变形而已,既然我们知道广度优先搜索,就应该知道用队列进行辅助输出。

当根节点是不存在的时候,那么就直接返回空数组就行了。

当根节点是存在的时候,我们就首先把根节点放入到队列当中。然后就开始进入一个循环:当队列不是空的时候,我们就开始遍历输出。因为队列里面有可能有很多结点,所以我们不一定就直接O(1)的方法来进行遍历,所以我们只能进行for循环进行遍历。我们需要知道队列的数目,所以需要用一个变量进行代替,这个循环就在这个队列当中遍历。

当我们开始对一个节点进行访问的时候,别忘记在访问的时候i把其踢出队列,防止重复访问。我们需要知道它是否有左子树或者说是右子树,有一个,两个还是都没有,我们需要判断一下。从左子树开始判断,再判断右子树,有的话就直接进入队列方便下次的遍历;如果没有就没有,不用做任何操作。

就这样进行循环完成之后,返回数组就行了。

注意:这里用的vector<vector<int>>数组,所以一开始是什么都没有的,所以需要在进行二维插入时候我们有一个操作就是:haha.push_back(vector<int>()),这样我们在进行二维的插入的时候才有空间可用。另外一点,我们没必要用数组的形式(比如haha[n].push_back())进行操作,我们可以随着循环的进行,一个一个插入。因此,我们用haha.back().push_back()就行了。

上代码:

/*** Definition for a binary tree node.* struct TreeNode {*     int val;*     TreeNode *left;*     TreeNode *right;*     TreeNode() : val(0), left(nullptr), right(nullptr) {}*     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}*     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}* };*/
class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {queue<TreeNode*>q;vector<vector<int>>haha;int k=0;if(!root)return haha;q.push(root);while(!q.empty()){int size=q.size();haha.push_back(vector<int>());for(int i=0;i<size;i++){TreeNode*res=q.front();haha.back().push_back(res->val);q.pop();if(res->left){q.push(res->left);}if(res->right){q.push(res->right);}}}return haha;}
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/682591.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

树莓派4B(Raspberry Pi 4B)使用docker搭建nacos集群

树莓派4B&#xff08;Raspberry Pi 4B&#xff09;使用docker搭建nacos集群 由于国内访问不了docker hub&#xff0c;我选用的国内适配树莓派ARM架构的nacos镜像——centralx/nacos-server。本文涉及到docker compose和docker network方面的知识&#xff0c;基于nacos 2.0.4&am…

《区块链公链数据分析简易速速上手小册》第4章:交易数据分析(2024 最新版)

文章目录 4.1 解析交易输入和输出4.1.1 基础知识4.1.2 重点案例&#xff1a;追踪比特币交易4.1.3 拓展案例 1&#xff1a;以太坊交易的输入输出解析拓展案例1&#xff1a;以太坊交易的输入输出解析步骤1: 连接到以太坊网络步骤2: 获取交易数据步骤3: 解析交易输入结论 4.1.4 拓…

LLM大模型相关问题汇总---包括问题与答案

一、基础篇 1. 目前主流的开源模型体系有哪些&#xff1f; - Transformer体系&#xff1a;由Google提出的Transformer模型及其变体&#xff0c;如BERT、GPT等。 - PyTorch Lightning&#xff1a;一个基于PyTorch的轻量级深度学习框架&#xff0c;用于快速原型设计和实验…

Uipath 调用Python 脚本程序详解

Python 活动概述 UiPath.Python.Activities 是一个新的活动包&#xff0c;创建它是为了支持直接从工作流运行 Python 脚本和方法。 其包含以下活动&#xff1a; Python 作用域(Python Scope) - 为 Python 活动提供作用域的容器。 加载 Python 脚本(Load Python Script) - 将 P…

A股上市以来涨幅排行榜

一、统计数据说明 1. 涨幅排行榜是根据股价的后复权价格计算的&#xff0c;该价格考虑了分红送股拆股等事件对股价的影响&#xff0c;相当于是分红再投资的股价。 2. 年化投资收益率&#xff0c;是根据IPO收盘价至今涨幅计算的复合年化收益率。例如&#xff0c;假设一个股票上…

中国电子学会2023年12月份青少年软件编程Scratch图形化等级考试试卷四级真题(含答案)

2023-12 Scratch四级真题 分数&#xff1a;100 题数&#xff1a;24 分数&#xff1a;60min 一、单选题(共10题&#xff0c;共30分) 1.运行下列程序&#xff0c;输入“abcdef”&#xff0c;程序结束后&#xff0c;变量“字符串”是&#xff1f;&#xff08;B&#xff09;(3…

代码随想录刷题笔记 DAY 26 | 组合总和 No.39 | 组合求和 II No.40 | 分割回文串 No.131

文章目录 Day 2501. 组合总和&#xff08;No. 39&#xff09;1.1 题目1.2 笔记1.3 代码 02. 组合求和 II&#xff08;No. 40&#xff09;2.1 题目2.2 笔记2.3 代码 03. 分割回文串&#xff08;No. 131&#xff09;3.1 题目3.2 笔记3.3 代码 Day 25 01. 组合总和&#xff08;No…

re:从0开始的CSS之旅 16. 高度塌陷问题

1. 高度塌陷问题 高度塌陷问题&#xff1a;在文档流中&#xff0c;父元素的高度默认是被子元素撑开的&#xff0c;子元素多高&#xff0c;父元素就多高。 但是当子元素设置浮动后&#xff0c;我们发现子元素在页面中的位置没变&#xff0c;但是父元素的高度却塌陷了&#xff0…

使用Xdisplay将ipad作为扩展显示器Agent闪退问题

1. 正常流程贴子挺多&#xff0c;可以参考这几篇 https://blog.csdn.net/Shi_Xueqing/article/details/129744496 如何将ipad作为win10的扩展屏&#xff08;使用USB线连接&#xff09;_ipad win usb 上网-CSDN博客 2.在进行pc端软件设置的时候发生闪退 解决方法&#xff1a…

Java入门高频考查基础知识9(银盛15问万字参考答案)

JAVA刷题专栏&#xff1a;http://t.csdnimg.cn/9qscL 目录 一、Springcloud的工作原理 三、注册中心心跳是几秒 四、消费者是如何发现服务提供者的 五、多个消费者调⽤用同⼀接口&#xff0c;eruka默认的分配⽅式是什么 六、springboot常用注解&#xff0c;及其实现 七、…

【算法】字符串匹配算法

文章目录 一、字符串匹配1. KMP2. 字符串哈希 一、字符串匹配 记&#xff1a;主串 s s s 长度为 m m m&#xff0c;子串 p p p 长度为 n n n。 1. KMP 暴力的做法&#xff0c;是在当前字符不匹配的时候&#xff0c;主串和子串都回溯&#xff0c;这样做显然是 O ( n m )…

使用R语言glmnet包进行正则化lasso回归

正则化的原理是尽可能多的将数据中的特征塞进最终模型&#xff0c;特征越多越可以更好地解释数据集的错综复杂。在应用正则化后&#xff0c;每个特征对模型部分的解释程度可能完全不同。通过使用正则化可以减少数据集的噪声&#xff0c;这些噪声可能来对最终模型几乎没有形象的…

苍穹外卖启动!

快捷键 Alt Enter&#xff1a;代码补全 ctrl 左键&#xff1a;进入这个方法 401 令牌校验出问题了&#xff0c;因为token过期了&#xff0c;在yml文件里设置的有效时间&#xff0c;过期之后&#xff0c;员工登陆&#xff0c;重新发送一下数据&#xff0c;获取新的token令牌…

车载常见概念

常见概念 ADAS&#xff08;Advanced Driver Assistance Systems&#xff09;是指先进驾驶辅助系统&#xff0c;是指车辆上装备的一系列技术&#xff0c;旨在提高驾驶员的安全性和驾驶舒适度。下面是ADAS中常见的名称和其英文全称和含义&#xff1a; LDWS&#xff08;Lane Depa…

ClickHouse--10--临时表、视图

提示&#xff1a;文章写完后&#xff0c;目录可以自动生成&#xff0c;如何生成可参考右边的帮助文档 文章目录 1.临时表1.1 特征1.2 创建一个临时表 2.视图2.1 普通视图2.2 物化视图 1.临时表 1.1 特征 ClickHouse 支持临时表&#xff0c;临时表具备以下特征&#xff1a; 当…

bat通过ssh增量同步文件夹

要通过 SSH 使用批处理文件&#xff08;.bat&#xff09;进行文件夹的增量同步&#xff0c;你可以使用 rsync 命令&#xff0c;这是一个非常强大的文件同步工具&#xff0c;它支持增量同步。以下是一个简单的批处理脚本示例&#xff0c;该脚本使用 SSH 连接到一个远程服务器&am…

【JAVA WEB】JavaScript(WebAPI)--DOM基本概念 获取元素 点击事件 键盘事件

目录 什么是WebAPI DOM的基本概念 DOM是什么 DOM树 获取元素 querySelector querySelectorAll 事件 事件初识 基本概念 事件三要素 点击事件 键盘事件 什么是WebAPI 前端学习的 JS 分成三个大的部分 ECMAScript&#xff1a;基础语法部分DOM API&#xff1a;操作…

鸿蒙开发系列教程(十九)--页面内动画(2)

组件内转场动画 组件的插入、删除过程即为组件本身的转场过程&#xff0c;组件的插入、删除动画称为组件内转场动画。通过组件内转场动画&#xff0c;可定义组件出现、消失的效果。 transition(value: TransitionOptions) 参数可以定义平移、透明度、旋转、缩放这几种转场样…

评估方法:CMMI/能力成熟度模型集成

一、什么是CMMI CMMI&#xff0c;全称为Capability Maturity Model Integration&#xff0c;即能力成熟度模型集成。它是由美国卡内基梅隆大学软件工程研究所研发的过程改进模型&#xff0c;也是国际上用于评价软件企业能力成熟度的一项重要标准。 CMMI的目的是帮助软件企业对…

中小学信息学奥赛CSP-J认证 CCF非专业级别软件能力认证-入门组初赛模拟题第一套(完善程序题)

CCF认证CSP-J入门组模拟测试题第一套 三、完善程序题 第一题 九宫格 请完善下面的程序,将1~9个数字分别填人3x3的九宫格中,第一行的三个数字组成一个三位数。要使第二行的三位数是第一行的2倍,第三行的三位数是第一行的3倍且每个格子里的数字都不能重复,现在要求输出所有的填…