12.翻转、对称二叉树,二叉树的深度

反转二叉树

递归写法

很简单

class Solution {
public:TreeNode* invertTree(TreeNode* root) {if(root==nullptr)return root;TreeNode* tmp;tmp=root->left;root->left=root->right;root->right=tmp;invertTree(root->left);invertTree(root->right);return root;}
};

迭代写法

先序遍历

class Solution {
public:TreeNode* invertTree(TreeNode* root) {stack<TreeNode*> sta;if(root)sta.push(root);TreeNode* cur;while(!sta.empty()){cur=sta.top();sta.pop();if(cur->left)sta.push(cur->left);if(cur->right)sta.push(cur->right);TreeNode* tmp=cur->left;cur->left=cur->right;cur->right=tmp;}return root;}
};

后序也可以;

但是中序遍历不行;

class Solution {
public:TreeNode* invertTree(TreeNode* root) {stack<TreeNode*> sta;if(root)sta.push(root);TreeNode* cur;while(!sta.empty()){cur=sta.top();sta.pop();if(cur){if(cur->right)sta.push(cur->right);sta.push(cur);sta.push(nullptr);if(cur->left)sta.push(cur->left);}else{cur=sta.top();sta.pop();TreeNode* tmp=cur->left;cur->left=cur->right;cur->right=tmp;}}return root;}
};

但是这个是可以过oj的

对称二叉树

反转之后再和原来的树比较,一模一样就是对称的。

但是这样还要复制一棵树,浪费空间。

应该两个指针同时遍历,镜像遍历:

只能是后序遍历?

  • 前序遍历

image-20250210210421096

这种情况会出现假阳性,根本在于前序遍历不能唯一标识一棵树

  • 中序遍历

同理,中序遍历也不能唯一标识一棵树:加法的二义性

image-20250210211147749

  • 后序遍历

后序遍历也不能唯一标识一棵树,例子同前序遍历的例子。

所以:并非只有后序遍历才行

class Solution {
public:bool Compare(TreeNode* cur1,TreeNode* cur2){if(cur1->left&&cur2->right){if(cur1->left->val!=cur2->right->val)return 0;}else if(cur1->left&&!cur2->right){return 0;}else if(!cur1->left&&cur2->right){return 0;}if(cur2->left&&cur1->right){if(cur2->left->val!=cur1->right->val)return 0;}else if(cur2->left&&!cur1->right){return 0;}else if(!cur2->left&&cur1->right){return 0;}return 1;}bool isSymmetric(TreeNode* root) {stack<TreeNode*> sta1;stack<TreeNode*> sta2;if(root){sta1.push(root);sta2.push(root);}TreeNode* cur1,*cur2;while(!sta1.empty()&&!sta2.empty()){cur1=sta1.top();sta1.pop();cur2=sta2.top();sta2.pop();if(!Compare(cur1,cur2))return 0;if(cur1->right)sta1.push(cur1->right);if(cur1->left)sta1.push(cur1->left);if(cur2->left)sta2.push(cur2->left);if(cur2->right)sta2.push(cur2->right);}return 1;}
};

只需要在比较时添加上子节点的因素,就可以避免假阳性

二叉树最大深度

层序遍历

class Solution {
public:int maxDepth(TreeNode* root) {queue<TreeNode*> que;if(root) que.push(root);int cur_size=1,nxt_size=0;int depth=0;while(!que.empty()){TreeNode* cur=que.front();que.pop();if(cur->left){nxt_size++;que.push(cur->left);}if(cur->right){nxt_size++;que.push(cur->right);}if(--cur_size==0){depth++;cur_size=nxt_size;nxt_size=0;}}return depth;}
};

更简洁的写法:

class Solution {
public:int maxDepth(TreeNode* root) {if (root == NULL) return 0;int depth = 0;queue<TreeNode*> que;que.push(root);while(!que.empty()) {int size = que.size();depth++; // 记录深度for (int i = 0; i < size; i++) {TreeNode* node = que.front();que.pop();if (node->left) que.push(node->left);if (node->right) que.push(node->right);}}return depth;}
};

二叉树最小深度

层序遍历

class Solution {
public:int minDepth(TreeNode* root) {queue<TreeNode*> que;if(root) que.push(root);int cur_size=1,nxt_size=0;int depth=0;while(!que.empty()){TreeNode* cur=que.front();que.pop();if(!cur->left&&!cur->right)return depth+1;if(cur->left){nxt_size++;que.push(cur->left);}if(cur->right){nxt_size++;que.push(cur->right);}if(--cur_size==0){depth++;cur_size=nxt_size;nxt_size=0;}}return depth;}
};

->right){
nxt_size++;
que.push(cur->right);
}
if(–cur_size==0){
depth++;
cur_size=nxt_size;
nxt_size=0;
}

   }return depth;
}

};


> 判断有没有叶节点

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

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

相关文章

算法之 博弈问题

文章目录 巴什博弈292.Nim 游戏 尼姆博弈斐波那契博弈其他博弈1025.除数博弈 博弈问题&#xff0c;就是双方之间的PK,关注的重点是 谁先&#xff1f;以及A,B各自赢的条件 一般有数学问题&#xff0c;动态规划&#xff0c;搜索进行求解 巴什博弈 下面的这题Nim 游戏&#xff0c;…

Linux 安装 Ollama

1、下载地址 Download Ollama on Linux 2、有网络直接执行 curl -fsSL https://ollama.com/install.sh | sh 命令 3、下载慢的解决方法 1、curl -fsSL https://ollama.com/install.sh -o ollama_install.sh 2、sed -i s|https://ollama.com/download/ollama-linux|https://…

DDR原理详解

DDR原理详解 存储器主要分为只读存储器 ROM 和随机存取存储器 RAM两大类。 ROM&#xff1a;只读存储器 ROM 所存数据&#xff0c;一般是装入整机前事先写好的,整机工作过程中只能读出&#xff0c;ROM所存数据稳定&#xff0c;断电后所存数据也不会改变。 RAM&#xff1a;随机…

推荐一款 免费的SSL,自动续期

支持自动续期 、泛域名 、可视化所有证书时效性 、可配置CDN 的一款工具。免费5个泛域名和1个自动更新。 链接 支持&#xff1a;nginx、通配符证书、七牛云、腾讯云、阿里云、CDN、OSS、LB&#xff08;负载均衡&#xff09; 执行自动部署脚本 提示系统过缺少crontab 安装cro…

手写一个C++ Android Binder服务及源码分析

手写一个C Android Binder服务及源码分析 前言一、 基于C语言编写Android Binder跨进程通信Demo总结及改进二、C语言编写自己的Binder服务Demo1. binder服务demo功能介绍2. binder服务demo代码结构图3. binder服务demo代码实现3.1 IHelloService.h代码实现3.2 BnHelloService.c…

将 AMD Zynq™ RFSoC 扩展到毫米波领域

目录 将 AMD Zynq™ RFSoC 扩展到毫米波领域Avnet XRF RFSoC 系统级模块适用于 MATLAB 的 Avnet RFSoC Explorer 工具箱5G mmWave PAAM 开发平台突破性的宽带毫米波波束成形特征&#xff1a;OTBF103 Mathworks Simulink 模型优化毫米波应用中的射频信号路径 用于宽带毫米波上/下…

征程 6 相比征程 5 对算子支持扩展的具体案例讲解

引言 征程 6 相比于征程 5&#xff0c;在整体架构上得到了升级&#xff0c;相对应的&#xff0c;算法工具链的算子支持也得到了扩充&#xff0c;无论是算子支持的数量&#xff0c;还是 BPU 约束条件&#xff0c;征程 6 都有明显的加强&#xff0c;这就使得过去在征程 5 上无法…

蓝桥杯C语言组:博弈问题

概述 在编程的世界里&#xff0c;博弈问题就像是一场智力的“斗地主”&#xff0c;双方&#xff08;或者多方&#xff09;使出浑身解数&#xff0c;只为赢得最后的胜利。而蓝桥杯C语言比赛中的博弈问题&#xff0c;更是让无数参赛者又爱又恨的存在。它们就像是隐藏在代码森林中…

BS架构(笔记整理)

楔子.基本概念 1.在网络架构中&#xff1a; 服务器通常是集中式计算资源&#xff0c;负责处理和存储数据&#xff1b;客户机是请求这些服务的终端设备&#xff0c;可能是个人电脑或移动设备&#xff1b;浏览器则是客户机上用来与服务器交互的工具&#xff0c;负责展示网页内容…

【动态规划篇】:动态规划解决路径难题--思路,技巧与实例

✨感谢您阅读本篇文章&#xff0c;文章内容是个人学习笔记的整理&#xff0c;如果哪里有误的话还请您指正噢✨ ✨ 个人主页&#xff1a;余辉zmh–CSDN博客 ✨ 文章所属专栏&#xff1a;动态规划篇–CSDN博客 文章目录 一.动态规划中的路径问题1.核心思路2.注意事项 二.例题讲解…

【Linux】深入理解linux权限

&#x1f31f;&#x1f31f;作者主页&#xff1a;ephemerals__ &#x1f31f;&#x1f31f;所属专栏&#xff1a;Linux 目录 前言 一、权限是什么 二、用户和身份角色 三、文件属性 1. 文件属性表示 2. 文件类型 3. 文件的权限属性 四、修改文件的权限属性和角色 1. …

嵌入式linux系统中VIM编辑工具用法与GCC参数详解

大家好,今天主要给大家分享一下,如何使用linux系统中的VIM编辑工具和GCC的参数详解。 第一:安装VIM 命令:sudo apt get install vim 第二:工作模式 普通模式:打开一个文件时的默认模式,按ESC返回普通模式 插入模式:i/o/a进入插入模式,不同在于在光标前后插入 可视…

【前端开发】HTML+CSS+JavaScript前端三剑客的基础知识体系了解

前言 &#x1f31f;&#x1f31f;本期讲解关于HTMLCSSJavaScript的基础知识&#xff0c;小编带领大家简单过一遍~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 …

蓝桥杯---数青蛙(leetcode第1419题)

文章目录 1.题目重述2.例子分析3.思路分析4.思路总结5.代码解释 1.题目重述 这个题目算是模拟这个专题里面的一类比较难的题目了&#xff0c;他主要是使用crock这个单词作为一个整体&#xff0c;让我们确定&#xff1a;给你一个字符串&#xff0c;至少需要多少个青蛙进行完成鸣…

WidowX-250s 机械臂学习记录

官网教程&#xff1a;Python Demos — Interbotix X-Series Arms Documentation 系统&#xff1a;Ubuntu20.04&#xff0c;ROS1 相关的硬件编译配置跳过 Python Demos 这些演示展示了使用 Interbotix Python Arm 模块的各种方法&#xff08;点击链接查看完整的代码文档&…

【CubeMX-HAL库】STM32F407—无刷电机学习笔记

目录 简介&#xff1a; 学习资料&#xff1a; 跳转目录&#xff1a; 一、工程创建 二、板载LED 三、用户按键 四、蜂鸣器 1.完整IO控制代码 五、TFT彩屏驱动 六、ADC多通道 1.通道确认 2.CubeMX配置 ①开启对应的ADC通道 ②选择规则组通道 ③开启DMA ④开启ADC…

集成右键的好用软件,支持多线程操作!

今天给大家分享一个超级实用的小工具&#xff0c;真的能帮上大忙呢&#xff01;这个软件是吾爱大神无知灰灰精心制作的&#xff0c;简直就是图片转换界的“小能手”。 它能一键把webp格式的图片转换成png格式&#xff0c;而且速度超快&#xff0c;完全不输那些付费的软件&#…

CSDN 博客之星 2024:肖哥弹架构的社区耕耘总结

#博客之星2024年度总评选—主题文章创作# CSDN 博客之星 2024&#xff1a;肖哥弹架构的社区耕耘总结 肖哥弹架构 是一位专注于技术分享和社区建设的博客作者。今年&#xff0c;我荣幸地再次入选CSDN博客之星TOP300&#xff0c;这不仅是对我过去努力的认可&#xff0c;更是对未…

【分布式理论7】分布式调用之:服务间的(RPC)远程调用

文章目录 一、RPC 调用过程二、RPC 动态代理&#xff1a;屏蔽远程通讯细节1. 动态代理示例2. 如何将动态代理应用于 RPC 三、RPC序列化与协议编码1. RPC 序列化2. RPC 协议编码2.1. 协议编码的作用2.2. RPC 协议消息组成 四、RPC 网络传输1. 网络传输流程2. 关键优化点 一、RPC…

综合评价 | 基于随机变异系数-TOPSIS组合法的综合评价模型(Matlab)

基于随机变异系数-TOPSIS组合法的综合评价模型 代码获取私信回复&#xff1a;综合评价 | 基于随机变异系数-TOPSIS组合法的综合评价模型&#xff08;Matlab&#xff09; 一、引言 1.1、研究背景与意义 在现代社会&#xff0c;随着信息量的不断增加和数据复杂性的提升&#…