代码随想录训练营第十四天 226翻转二叉树 101对称二叉树 104二叉树的最大深度 111二叉树的最小深度

本文主要是介绍代码随想录训练营第十四天 226翻转二叉树 101对称二叉树 104二叉树的最大深度 111二叉树的最小深度,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

第一题:

原题链接:226. 翻转二叉树 - 力扣(LeetCode)

思路:

递归法:使用中序遍历的操作,中左右,在遍历到中间节点的时候对它左右节点进行交换。

代码如下:

/*** 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:TreeNode* invertTree(TreeNode* root) {if(root == nullptr) return root;TreeNode* node = root;TreeNode* tmp = node -> left;node -> left = node -> right;node -> right = tmp;if(node -> left) invertTree(node -> left);if(node -> right) invertTree(node -> right);return node;}
};

第二题:

原题链接:101. 对称二叉树 - 力扣(LeetCode)

思路:我们要明白的是我们要比较的是左右子树是否相等。我们不能使用前序遍历,这样比较的不全面。我们使用后序遍历的方式。

这道题我们的递归的条件比较多,分为了五种情况。

第一种左节点和右节点都为空,则返回true;

第二种左节点为空右节点不为空,返回false;

第三种左节点不为空右节点为空,返回false;

第四种左节点和右节点的值不等,返回false;

第五种左节点和右节点的值相等那么进入单层递归逻辑。也就是判断比较二叉树的外侧是否对称和比较内侧是否对称。如果都为true返回true,如果其中一个部位true返回false;

代码如下:

/*** 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:bool isSymmetric(TreeNode* root) {if(root == nullptr) return true;return isSame(root -> left, root -> right);}
private:bool isSame(TreeNode* left, TreeNode* right){if(left == nullptr && right == nullptr) return true;if(left == nullptr && right != nullptr) return false;if(left != nullptr && right == nullptr) return false;if(left -> val != right -> val) return false;bool outside = isSame(left -> left, right -> right);bool inside = isSame(left -> right, right -> left);return outside && inside;}
};

第三题:

原题链接:104. 二叉树的最大深度 - 力扣(LeetCode)

思路:使用后序遍历的方式,遍历顺序是左右中。一直遍历到底部,然后取左右子节点中较大的深度再加一返回给上层,最后传递到根节点的值就是最大深度。

代码如下:

/*** 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:int maxDepth(TreeNode* root) {return getDepth(root);}
private:int getDepth(TreeNode* node){if(node == nullptr) return 0;int leftD = getDepth(node -> left);int rightD = getDepth(node -> right);int res = 1 + max(leftD, rightD);return res;}
};

第四题:

原题链接:111. 二叉树的最小深度 - 力扣(LeetCode)

思路:

注意本题最小深度是从根节点到最近叶子节点的最短路劲上的节点数量,注意是叶子节点,什么是叶子节点,左右孩子都为空的节点才是叶子节点。

我们依旧使用后序遍历的方式。

一直遍历到底部,然后向上返回左右子节点中较小的一个的路径。其中需要注意的是在如果左子树为空,右子树不为空的情况下最小深度是1 + 右子树的深度,反之,右子树为空,左子树不为空的情况下返回的是1 + 左子树的深度。如果左右子树都不为空的情况下返回的是左右子树深度的最小值 + 1;

代码如下:

/*** 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:int minDepth(TreeNode* root) {return getDepth(root);}
private:int getDepth(TreeNode* node){if(node == nullptr) return 0;int leftD = getDepth(node -> left);int rightD = getDepth(node -> right);if(node -> left == nullptr && node -> right != nullptr){return 1 + rightD;}if(node -> left != nullptr && node -> right == nullptr){return 1 + leftD;}int res = 1 + min(leftD, rightD);return res;}
};

这篇关于代码随想录训练营第十四天 226翻转二叉树 101对称二叉树 104二叉树的最大深度 111二叉树的最小深度的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1077132

相关文章

Spring Boot 3.4.3 基于 Spring WebFlux 实现 SSE 功能(代码示例)

《SpringBoot3.4.3基于SpringWebFlux实现SSE功能(代码示例)》SpringBoot3.4.3结合SpringWebFlux实现SSE功能,为实时数据推送提供... 目录1. SSE 简介1.1 什么是 SSE?1.2 SSE 的优点1.3 适用场景2. Spring WebFlu

java之Objects.nonNull用法代码解读

《java之Objects.nonNull用法代码解读》:本文主要介绍java之Objects.nonNull用法代码,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录Java之Objects.nonwww.chinasem.cnNull用法代码Objects.nonN

SpringBoot实现MD5加盐算法的示例代码

《SpringBoot实现MD5加盐算法的示例代码》加盐算法是一种用于增强密码安全性的技术,本文主要介绍了SpringBoot实现MD5加盐算法的示例代码,文中通过示例代码介绍的非常详细,对大家的学习... 目录一、什么是加盐算法二、如何实现加盐算法2.1 加盐算法代码实现2.2 注册页面中进行密码加盐2.

python+opencv处理颜色之将目标颜色转换实例代码

《python+opencv处理颜色之将目标颜色转换实例代码》OpenCV是一个的跨平台计算机视觉库,可以运行在Linux、Windows和MacOS操作系统上,:本文主要介绍python+ope... 目录下面是代码+ 效果 + 解释转HSV: 关于颜色总是要转HSV的掩膜再标注总结 目标:将红色的部分滤

Python 中的异步与同步深度解析(实践记录)

《Python中的异步与同步深度解析(实践记录)》在Python编程世界里,异步和同步的概念是理解程序执行流程和性能优化的关键,这篇文章将带你深入了解它们的差异,以及阻塞和非阻塞的特性,同时通过实际... 目录python中的异步与同步:深度解析与实践异步与同步的定义异步同步阻塞与非阻塞的概念阻塞非阻塞同步

在C#中调用Python代码的两种实现方式

《在C#中调用Python代码的两种实现方式》:本文主要介绍在C#中调用Python代码的两种实现方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录C#调用python代码的方式1. 使用 Python.NET2. 使用外部进程调用 Python 脚本总结C#调

Java时间轮调度算法的代码实现

《Java时间轮调度算法的代码实现》时间轮是一种高效的定时调度算法,主要用于管理延时任务或周期性任务,它通过一个环形数组(时间轮)和指针来实现,将大量定时任务分摊到固定的时间槽中,极大地降低了时间复杂... 目录1、简述2、时间轮的原理3. 时间轮的实现步骤3.1 定义时间槽3.2 定义时间轮3.3 使用时

Java中&和&&以及|和||的区别、应用场景和代码示例

《Java中&和&&以及|和||的区别、应用场景和代码示例》:本文主要介绍Java中的逻辑运算符&、&&、|和||的区别,包括它们在布尔和整数类型上的应用,文中通过代码介绍的非常详细,需要的朋友可... 目录前言1. & 和 &&代码示例2. | 和 ||代码示例3. 为什么要使用 & 和 | 而不是总是使

Java强制转化示例代码详解

《Java强制转化示例代码详解》:本文主要介绍Java编程语言中的类型转换,包括基本类型之间的强制类型转换和引用类型的强制类型转换,文中通过代码介绍的非常详细,需要的朋友可以参考下... 目录引入基本类型强制转换1.数字之间2.数字字符之间引入引用类型的强制转换总结引入在Java编程语言中,类型转换(无论

Redis中高并发读写性能的深度解析与优化

《Redis中高并发读写性能的深度解析与优化》Redis作为一款高性能的内存数据库,广泛应用于缓存、消息队列、实时统计等场景,本文将深入探讨Redis的读写并发能力,感兴趣的小伙伴可以了解下... 目录引言一、Redis 并发能力概述1.1 Redis 的读写性能1.2 影响 Redis 并发能力的因素二、