当前位置: 首页 > news >正文

LeetCode——2415. 反转二叉树的奇数层

通过万岁!!!

  • 题目:给你一个完全二叉树,然后将其奇数层进行反转。
  • 思路:这个题他都说了是奇数层了,那基本就是层序遍历了。但是存在两个问题,一个是如何判断奇数层,另外一个是如何进行交换。首先是第一个问题,如何判断是奇数层。这个问题比较简单,由于我们每次往数组中添加的都是左右两个节点的元素。因此,如果队列中的元素个数是2的n次方,并且n是一个奇数,则表示奇数层。然后就是反转了,这里需要借助一个list集合,我没有找到队列有反转的方法,如果有的话,空间复杂度可以小一点。值得注意的是,在最后一层元素出队的时候,也会遇到奇数层的情况,所以我们需要记录层数,层数必须是一直增加的。
  • 思路:层序遍历,队列。

java代码

class Solution {public TreeNode reverseOddLevels(TreeNode root) {if (root == null || root.left == null) {return root;}Queue<TreeNode> queue = new LinkedList<>();queue.add(root);int r;int l;double level = 0;while (queue.size() != 0) {TreeNode remove = queue.remove();if (remove.left != null) {queue.add(remove.left);}if (remove.right != null) {queue.add(remove.right);}r = queue.size() - 1;l = 0;double newLevel = Math.log(r + 1) / Math.log(2);if (newLevel < level) {continue;} else {level = newLevel;}// 如果是奇数层,则就需要进行交换了if (newLevel % 2 == 1) {List<TreeNode> transList = new ArrayList<>(r);for (TreeNode treeNode : queue) {transList.add(treeNode);}while (r > l) {int temp = transList.get(r).val;transList.get(r).val = transList.get(l).val;transList.get(l).val = temp;l++;r--;}}}return root;}
}
  • 总结:其实这个问题比较简单的。
http://www.lryc.cn/news/265662.html

相关文章:

  • 【Spring学习笔记】Spring 注解开发
  • 【华为数据之道学习笔记】6-5数据地图的核心价值
  • JavaWeb笔记之JSP
  • 在x64上构建智能家居(home assistant)(二)(新版Debain12)连接Postgresql数据库
  • 八股文打卡day6——计算机网络(6)
  • 【PHY6222】绑定详解
  • vue事件绑定
  • 如何在服务器上部署springboot项目
  • 基于Spring Boot的支教志愿者招聘网站
  • 安装gnvm,nodejs,npm使用方法
  • word导入导出-Apache POI 和 Poi-tl
  • Hadoop 集群环境搭建
  • maven完结,你真的学完了吗
  • 【Xcode】解决Unable to process request - PLA Update available
  • 力扣单调栈算法专题训练
  • 【NI-RIO入门】理解Windows、Real Time与FPGA之间数据通信的原理
  • 关于游戏性能优化的技巧
  • antdesignpro实现滚动加载分页数据
  • 步兵 cocos2dx 加密和混淆
  • 【算法设计与分析】——动态规划算法
  • WPF组合控件TreeView+DataGrid之DataGrid封装
  • PIL/Pillow
  • ARM 汇编入门
  • SQL进阶:多表查询
  • 多层负载均衡实现
  • Redis取最近10条记录
  • Mybatis之增删改查
  • Go 代码检查工具 golangci-lint
  • SwiftUI 趣谈之:绝不可能(Never)的 View!
  • etcd是什么