代码随想录算法训练营第15天| 102. 二叉树的层序遍历、226. 翻转二叉树、101. 对称二叉树

102. 二叉树的层序遍历

题目链接

102. 二叉树的层序遍历 - 力扣(LeetCode)

思路

 这道题的正常解法(迭代法)二刷时能做出来,bugfree,但是递归法没有掌握。

本人题解

class Solution {
public:vector<vector<int>> levelOrder(TreeNode* root) {//二叉树的层序遍历使用队列这种数据结构来做的//首先定义一个队列用于遍历二叉树queue<TreeNode*> myQue;//其次定义一个二维数组用于返回遍历的结果vector<vector<int>> res;if (root == NULL) return res;myQue.push(root);while (!myQue.empty()) {//定义一个int类型的变量用于记录每一层中有多少个节点int size = myQue.size();vector<int> num;while (size--) {TreeNode* node = myQue.front();myQue.pop();if (node->left) myQue.push(node->left);if (node->right) myQue.push(node->right);num.push_back(node->val);}res.push_back(num);}return res;}
};

226. 翻转二叉树

题目链接

226. 翻转二叉树 - 力扣(LeetCode)

思路

 这道题目的思路其实很简单,关于递归的解题思路自己也想到了,但是不自信 最后没做出来。。。

其实思路就可以理解为:将所有的节点的左右节点进行翻转一次就可以,所以这道题用层序遍历也是很简单。

101. 对称二叉树

思路

看了题解看懂

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

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

相关文章

Rust有没有信号量机制,在缓存有数据的时候才允许等待的进程取数据?

Rust提供了信号量&#xff08;Semaphore&#xff09;机制&#xff0c;尽管它并没有直接提供类似于某些其他编程语言中的Semaphore类。然而&#xff0c;你可以使用std::sync::Mutex和std::sync::Condvar&#xff08;条件变量&#xff09;组合来实现信号量的功能。 信号量通常用…

程序员书单推荐:从入门到精通的必读之作

在程序员的职业生涯中&#xff0c;阅读技术书籍是不断学习和提升自我的重要途径。本文将为你推荐一系列从入门到精通的程序员书单&#xff0c;帮助你系统地掌握编程知识、提高技能水平&#xff0c;并在职业生涯中取得更大的进步。 一、入门篇 《Head First C语言》&#xff1…

基于SpringBoot+Vue+ElementUI+Mybatis前后端分离管理系统超详细教程(一)

Vue.js 是一个流行的前端框架&#xff0c;用于构建用户界面和单页应用程序。Vue 2 是其第二个主要版本&#xff0c;它提供了数据绑定、组件化、虚拟DOM等核心特性。要搭建一个 Vue 2 的工程化项目&#xff0c;可以遵循以下步骤&#xff1a; 一、前端环境搭建 &#xff08;一&a…

Maven入门(作用,安装配置,Idea基础maven,Maven依赖,Maven构建项目)【详解】

目录 一. Maven的作用 1.依赖管理 2.统一项目结构 3.项目构建 二.Maven安装配置 1. Maven的仓库类型 2 加载jar的顺序 3. Maven安装配置 4.安装Maven 5.配置仓库 三.idea集成maven 1.给当前project集成maven 2.给新建project集成maven 3.创建maven项目 4.pom…

二维码门楼牌管理系统应用场景:地方社区管理的新利器

文章目录 前言一、地方社区管理部门的门牌信息利用二、与社区管理部门的联动效应三、结论 前言 随着信息技术的不断发展&#xff0c;二维码门楼牌管理系统逐渐成为地方社区管理的新宠。该系统通过集成二维码技术与门楼牌信息&#xff0c;为社区管理带来了前所未有的便利与高效…

git 最基本的几条命令

git 最基本的几条命令 初始化本地仓库和推送到远程仓库 打开命令提示符或PowerShell&#xff1a;在你的本地项目目录中&#xff0c;可以通过文件资源管理器地址栏输入cmd或PowerShell 并回车来打开初始化 Git&#xff1a;git init添加所有文件到新的Git仓库&#xff1a;git a…

Github 2024-03-07Go开源项目日报 Top10

根据Github Trendings的统计,今日(2024-03-07统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量Go项目10TypeScript项目1Harbor - 开源的云原生注册表项目 创建周期:2908 天开发语言:Go协议类型:Apache License 2.0Star数量:21549 个For…

2024年JSON 面试题目-1

以下是一些可能在2024年JSON相关的热点面试题目&#xff1a; 请解释JSON是什么&#xff0c;以及它与其他数据交换格式&#xff08;如XML&#xff09;相比有哪些优势&#xff1f; JSON (JavaScript Object Notation) 是一种轻量级的数据交换格式&#xff0c;它基于ECMAScript的一…

uniapp 解决请求出现 /sockjs-node/info?t=问题

1. uniapp请求出现 /sockjs-node/info?t问题 1.1. 问题 uniapp项目老是出现 http://192.168.2.106:8080/sockjs-node/info?t1709704280949 1.1. sockjs-node介绍 sockjs-node 是一个JavaScript库&#xff0c;提供跨浏览器JavaScript的API&#xff0c;创建了一个低延迟、全…

selinux规则

selinux状态 相关命令 进程要和文件的安全上下文相匹配&#xff0c;进程才能打开文件 查找这个命令从哪个安装包来的用 yum provides 命令 进程httpd 必须与ls -Z的文件类型一致&#xff0c;要不然在强制模式下面&#xff0c;打开不了 在终端2用此命令&#xff0c;把文件类型改…

【有趣】带照明灯的自行车“铃”

这个自行车“铃”发出的不是令行人刺耳讨厌的金属铃声&#xff0c;而是礼貌友好的“请让路&#xff0c;谢谢&#xff01;”声&#xff0c;新颖而有趣&#xff1b;照明灯则为夜间骑车带来方便&#xff0c;既保安全而又实用。整个装置成本不足10元&#xff0c;制作和安装使用也都…

微信小程序用户登陆和获取用户信息功能实现

官方文档&#xff1a; https://developers.weixin.qq.com/miniprogram/dev/framework/open-ability/login.html 接口说明&#xff1a; https://developers.weixin.qq.com/miniprogram/dev/OpenApiDoc/user-login/code2Session.html 我们看官方这个图&#xff0c;梳理一下用户…

本地项目推送到腾讯云轻量应用服务器教程(并实现本地推送远程自动更新)

将本地项目上传到腾讯云轻量应用服务器并实现后续的推送更新&#xff0c;具体步骤如下&#xff1a; 在本地项目目录下初始化 Git 仓库&#xff1a; cd 项目目录 git init将项目文件添加到 Git 仓库并提交&#xff1a; git add . git commit -m "Initial commit"在…

git 命令怎么回退到某个特定的 commit 并将其推送到远程仓库?

问题 不小心把提交的名称写错提交上远程仓库了&#xff0c;这里应该是 【029】的&#xff0c;这个时候我们想回到【028】这一个提交记录&#xff0c;然后再重新提交【029】到远程仓库&#xff0c;该怎么处理。 解决 1、首先我们找到【028】这条记录的提交 hash&#xff0c;右…

centos cat命令

cat命令主要有两个功能&#xff1a;显示文件内容和创建文件&#xff1a; 1. 显示文件内容cat /dev/opt/text.log 2. 在终端中查看多个文件的内容 cat test1.txt test2.txt 3. 在终端显示文件内容带行号 cat -n test1.txt 4. 将标准输出与重定向运算符一起使用 cat t…

Android Q - 应用保活记录(展锐平台)

有其他同事改过这方面的问题&#xff0c;仅在此作个记录&#xff0c;方便查阅。 1、lmkd白名单 1).device/sprd/sharkle/common/lmkd_param.conf# format: title and string # TITLE_ for different usage # string detail information for every TITLE.####TITLE_LM…

rust-analyzer报错“Failed to spawn one or more proc-macro servers,....“怎么解决?

最近,在使用vscode测试rust代码时,遇到了一些问题。在经过反复折腾后,最终解决了问题,在此写下作为记录,以便于以后参考。 我遇到的报错内容是: Failed to spawn one or more proc-macro servers. cannot find proc-macro-srv, the workspace E:\100rust\temp is missin…

Timsort排序

Timsort 是一种混合排序算法&#xff0c;由 Tim Peters 在 2002 年为 Python 的标准库设计。它结合了归并排序&#xff08;Merge Sort&#xff09;和插入排序&#xff08;Insertion Sort&#xff09;的优点&#xff0c;特别适用于处理部分有序的数据集。Timsort 在 Python 中用…

目标检测YOLO实战应用案例100讲-【目标检测】基于图像处理的机器人垃圾分拣系统(续)

目录 3 基于YOLOv8的机器人垃圾分拣系统研究 3.1 引言 3.2 基于YOLOv8的机器人垃圾分拣系统设计方案

阿俊带你用Kotlin刷算法(五)

本系列通过Java和Kotlin这两种语言来解决力扣上面的算法题&#xff0c;由于本人算法菜鸟一枚&#xff0c;可能部分题目并不是最优题解&#xff0c;希望能和各位大神共同讨论~ 阿俊带你用Kotlin刷算法&#xff08;一&#xff09; 阿俊带你用Kotlin刷算法&#xff08;二&#x…