【每日一题】【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

相关文章

【每日一题】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

力扣 739. 每日温度【经典单调栈题目】

1. 题目 理解题意: 1.1. 给一个温度集合, 要返回一个对应长度的结果集合, 这个结果集合里面的元素 i 是 当前 i 位置的元素的下一个更高温度的元素的位置和当前 i 位置的距离之差, 若是当前元素不存在下一个更高温度的元素, 则这个位置用0代替; 2. 思路 本题用单调栈来求解;单调栈就适用于来求当前元素左边或者右边第一个比当前元素大或者小的元素;【单调栈:让栈中的元素保持单调

在二叉树中找到两个节点的最近公共祖先(基于Java)

如题  题解 public int lowestCommonAncestor(TreeNode root, int o1, int o2) {//记录遍历到的每个节点的父节点。Map<Integer, Integer> parent = new HashMap<>();Queue<TreeNode> queue = new LinkedList<>();parent.put(roo

数据结构--二叉树(C语言实现,超详细!!!)

文章目录 二叉树的概念代码实现二叉树的定义创建一棵树并初始化组装二叉树前序遍历中序遍历后序遍历计算树的结点个数求二叉树第K层的结点个数求二叉树高度查找X所在的结点查找指定节点在不在完整代码 二叉树的概念 二叉树(Binary Tree)是数据结构中一种非常重要的树形结构,它的特点是每个节点最多有两个子节点,通常称为左子节点和右子节点。这种结构使得二叉树在数据存储和查找等方面具