【每日一题】【12.15】2415.反转二叉树的奇数层

2023-12-15 13:52

本文主要是介绍【每日一题】【12.15】2415.反转二叉树的奇数层,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 🔥博客主页: A_SHOWY
🎥系列专栏:力扣刷题总结录 数据结构  云计算  数字图像处理  力扣每日一题_

2415. 反转二叉树的奇数层icon-default.png?t=N7T8https://leetcode.cn/problems/reverse-odd-levels-of-binary-tree/

今天终于碰到了一个mid题目,不用经受hard题目的折磨了,是一个树的反转问题,我们可以从深度优先遍历和广度优先遍历两种方法进行求解。深度的话,奇数层就翻转,然后对应的部分再进行递归就可以。广度的话代码复杂一些但是思路简单,不用递归,将奇数层数的存到数组中,后续判定是奇数层就反转。一层一层解决。

方法一: 深度优先遍历 

  • 在遍历每一层的时候 ,root1和root2分别指向这一层可能需要交换的两个结点,根据完美二叉树的反转规则,即左边排第一的元素与倒数第一元素进行交换,第二个元素与倒数二个元素交换,此时root1的左孩子和root2的右孩子换,root1的右孩子和root2的左孩子交换,在遍历的同时按照上述规则,将配对的节点进行递归传递到下一层;
  • isOdd来表示是否为奇数,偶数层不需要交换,在递归的时候急着进行一个isOdd取逆的操作。
  • 注意当左子树为空的时候,直接返回。

总体代码 

class Solution {
public:TreeNode* reverseOddLevels(TreeNode* root) {dfs(root-> left,root ->right,true);return root;}void dfs(TreeNode* root1,TreeNode* root2,bool isOdd){if(root1 == NULL) return;//判定是不是奇数if(isOdd) {swap(root1->val,root2->val);}dfs(root1 -> left,root2 -> right,!isOdd);dfs(root1 -> right,root2 -> left, !isOdd);}
};

方法二: 广度优先遍历 

  • 在遍历的同时,对每一层进行标记,如果当前该层为奇数层,则将该层中的节点用数组保存起来,然后将该层所有节点的值进行反转即可。
  • 判断有左子树的时候,就继续存下一层
  • 反转swap的时候使用了简单的双指针,一定要记住->val
  • 记住最后再取反
    isOdd ^= true;

总体代码: 

class Solution {
public:TreeNode* reverseOddLevels(TreeNode* root) {queue<TreeNode *> q;//根结点导进去q.emplace(root);bool isOdd = false;while(!q.empty()){int sz = q.size();vector<TreeNode *> reverse;for(int i =0; i< sz; i++){TreeNode* node = q.front();q.pop();if(isOdd){reverse.push_back(node);}//如果有左子节点导入队列,为了下一层if(node -> left){q.emplace(node-> left);q.emplace(node-> right);}}//奇数就翻转,双指针if(isOdd){for(int l =0,r = sz -1;l < r;l++,r--){swap(reverse[l] -> val,reverse[r]-> val);}}isOdd ^= true;//取反;}return root;}};

 

这篇关于【每日一题】【12.15】2415.反转二叉树的奇数层的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

使用C++实现链表元素的反转

《使用C++实现链表元素的反转》反转链表是链表操作中一个经典的问题,也是面试中常见的考题,本文将从思路到实现一步步地讲解如何实现链表的反转,帮助初学者理解这一操作,我们将使用C++代码演示具体实现,同... 目录问题定义思路分析代码实现带头节点的链表代码讲解其他实现方式时间和空间复杂度分析总结问题定义给定

Spring IOC控制反转的实现解析

《SpringIOC控制反转的实现解析》:本文主要介绍SpringIOC控制反转的实现,IOC是Spring的核心思想之一,它通过将对象的创建、依赖注入和生命周期管理交给容器来实现解耦,使开发者... 目录1. IOC的基本概念1.1 什么是IOC1.2 IOC与DI的关系2. IOC的设计目标3. IOC

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟)

【每日一题】LeetCode 2181.合并零之间的节点(链表、模拟) 题目描述 给定一个链表,链表中的每个节点代表一个整数。链表中的整数由 0 分隔开,表示不同的区间。链表的开始和结束节点的值都为 0。任务是将每两个相邻的 0 之间的所有节点合并成一个节点,新节点的值为原区间内所有节点值的和。合并后,需要移除所有的 0,并返回修改后的链表头节点。 思路分析 初始化:创建一个虚拟头节点

leetcode105 从前序与中序遍历序列构造二叉树

根据一棵树的前序遍历与中序遍历构造二叉树。 注意: 你可以假设树中没有重复的元素。 例如,给出 前序遍历 preorder = [3,9,20,15,7]中序遍历 inorder = [9,3,15,20,7] 返回如下的二叉树: 3/ \9 20/ \15 7   class Solution {public TreeNode buildTree(int[] pr

每日一题|牛客竞赛|四舍五入|字符串+贪心+模拟

每日一题|四舍五入 四舍五入 心有猛虎,细嗅蔷薇。你好朋友,这里是锅巴的C\C++学习笔记,常言道,不积跬步无以至千里,希望有朝一日我们积累的滴水可以击穿顽石。 四舍五入 题目: 牛牛发明了一种新的四舍五入应用于整数,对个位四舍五入,规则如下 12345->12350 12399->12400 输入描述: 输入一个整数n(0<=n<=109 ) 输出描述: 输出一个整数

控制反转 的种类

之前对控制反转的定义和解释都不是很清晰。最近翻书发现在《Pro Spring 5》(免费电子版在文章最后)有一段非常不错的解释。记录一下,有道翻译贴出来方便查看。如有请直接跳过中文,看后面的原文。 控制反转的类型 控制反转的类型您可能想知道为什么有两种类型的IoC,以及为什么这些类型被进一步划分为不同的实现。这个问题似乎没有明确的答案;当然,不同的类型提供了一定程度的灵活性,但

每日一练7:简写单词(含链接)

1.链接 简写单词_牛客题霸_牛客网 2.题目 3.代码1(错误经验) #include <iostream>#include <string>using namespace std;int main() {string s;string ret;int count = 0;while(cin >> s)for(auto a : s){if(count == 0){if( a <=

【每日刷题】Day113

【每日刷题】Day113 🥕个人主页:开敲🍉 🔥所属专栏:每日刷题🍍 🌼文章目录🌼 1. 91. 解码方法 - 力扣(LeetCode) 2. LCR 098. 不同路径 - 力扣(LeetCode) 3. 63. 不同路径 II - 力扣(LeetCode) 1. 91. 解码方法 - 力扣(LeetCode) //思路:动态规划。 cl

PHP实现二叉树遍历(非递归方式,栈模拟实现)

二叉树定义是这样的:一棵非空的二叉树由根结点及左、右子树这三个基本部分组成,根据节点的访问位置不同有三种遍历方式: ① NLR:前序遍历(PreorderTraversal亦称(先序遍历)) ——访问结点的操作发生在遍历其左右子树之前。 ② LNR:中序遍历(InorderTraversal) ——访问结点的操作发生在遍历其左右子树之中(间)。 ③ LRN:后序遍历(PostorderT