剑指 Offer 32 - III. 从上到下打印二叉树 III

请实现一个函数按照之字形顺序打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右到左的顺序打印,第三行再按照从左到右的顺序打印,其他行以此类推。

例如:

给定二叉树: [3,9,20,null,null,15,7],

给定二叉树: [3,9,20,null,null,15,7],

  1. 3
  2. / \
  3. 9 20
  4. / \
  5. 15 7

返回其层次遍历结果:

  1. [
  2. [3],
  3. [20,9],
  4. [15,7]
  5. ]

提示:

  • 节点总数 <= 1000

一、层序遍历 + 双端队列

做题思路:与剑指 Offer 32 - I. 从上到下打印二叉树 - RainsX - 博客园 (cnblogs.com)剑指 Offer 32 - II. 从上到下打印二叉树 II - RainsX - 博客园 (cnblogs.com)类似,只是在BFS循环的时候加入了判断奇偶数的判定。当res.size()为偶数的时候,添加node.val的头部,否则为尾部。

而且这道题可以与剑指 Offer 32 - I. 从上到下打印二叉树 - RainsX - 博客园 (cnblogs.com)剑指 Offer 32 - II. 从上到下打印二叉树 II - RainsX - 博客园 (cnblogs.com)一起连着做,然后加深对BFS和输的理解。

个人建议,可以试着把这个代码部分模块当做模板来熟悉,因为后续可能也有同样的算法题需要此类模板。

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public List<List<Integer>> levelOrder(TreeNode root) {
  12. Queue<TreeNode> deque = new LinkedList<>();
  13. List<List<Integer>> res = new ArrayList<List<Integer>>();
  14. if(root != null) deque.add(root);
  15. while(!deque.isEmpty()) {
  16. LinkedList<Integer> tmp = new LinkedList<>();
  17. for (int i = deque.size(); i>0; i--) {
  18. TreeNode node = deque.poll();
  19. if (res.size() % 2 == 0) tmp.addLast(node.val);
  20. else tmp.addFirst(node.val);
  21. if (node.left != null) deque.add(node.left);
  22. if (node.right != null) deque.add(node.right);
  23. }
  24. res.add(tmp);
  25. }
  26. return res;
  27. }
  28. }

二、层序遍历 + 双端队列(奇偶层逻辑分离)

这个做题思路是K神的思路,比起一开始简化了很多步骤,这个梗容易看懂一些。

算法流程如下:

BFS循环

  • 循环打印奇数/偶数层,当deque为空时候跳出
  • 打印奇数层的时候,依次从左到右
  • 打印偶数层的时候,依次从右到左
  1. class Solution {
  2. public List<List<Integer>> levelOrder(TreeNode root) {
  3. Deque<TreeNode> deque = new LinkedList<>();
  4. List<List<Integer>> res = new ArrayList<>();
  5. if(root != null) deque.add(root);
  6. while(!deque.isEmpty()) {
  7. // 打印奇数层
  8. List<Integer> tmp = new ArrayList<>();
  9. for(int i = deque.size(); i > 0; i--) {
  10. // 从左向右打印
  11. TreeNode node = deque.removeFirst();
  12. tmp.add(node.val);
  13. // 先左后右加入下层节点
  14. if(node.left != null) deque.addLast(node.left);
  15. if(node.right != null) deque.addLast(node.right);
  16. }
  17. res.add(tmp);
  18. if(deque.isEmpty()) break; // 若为空则提前跳出
  19. // 打印偶数层
  20. tmp = new ArrayList<>();
  21. for(int i = deque.size(); i > 0; i--) {
  22. // 从右向左打印
  23. TreeNode node = deque.removeLast();
  24. tmp.add(node.val);
  25. // 先右后左加入下层节点
  26. if(node.right != null) deque.addFirst(node.right);
  27. if(node.left != null) deque.addFirst(node.left);
  28. }
  29. res.add(tmp);
  30. }
  31. return res;
  32. }
  33. }

三、层序遍历 + 倒序

这个倒序的思路,其实只要懂了判断奇数/偶数层,就更容易什么时候倒序。

  1. /**
  2. * Definition for a binary tree node.
  3. * public class TreeNode {
  4. * int val;
  5. * TreeNode left;
  6. * TreeNode right;
  7. * TreeNode(int x) { val = x; }
  8. * }
  9. */
  10. class Solution {
  11. public List<List<Integer>> levelOrder(TreeNode root) {
  12. Queue<TreeNode> queue = new LinkedList<>();
  13. List<List<Integer>> res = new ArrayList<>();
  14. if (root != null) queue.add(root);
  15. while (!queue.isEmpty()) {
  16. List<Integer> tmp = new ArrayList<>();
  17. for (int i = queue.size(); i > 0; i--) {
  18. TreeNode node = queue.poll();
  19. tmp.add(node.val);
  20. if (node.left != null) queue.add(node.left);
  21. if (node.right != null) queue.add(node.right);
  22. }
  23. //当偶数层的时候就倒序,就跟方法一一样改变顺序即可
  24. if (res.size() % 2 != 0) Collections.reverse(tmp);
  25. res.add(tmp);
  26. }
  27. return res;
  28. }
  29. }

参考链接:

https://leetcode-cn.com/problems/cong-shang-dao-xia-da-yin-er-cha-shu-iii-lcof/solution/mian-shi-ti-32-iii-cong-shang-dao-xia-da-yin-er--3/

剑指 Offer 32 - III. 从上到下打印二叉树 III的更多相关文章

  1. 剑指 Offer 32 - II. 从上到下打印二叉树 II + 层次遍历二叉树 + 按层存储

    剑指 Offer 32 - II. 从上到下打印二叉树 II Offer_32 题目描述: 题解分析: 这道题我一开始想到的解决方法较粗暴,就是使用两个变量来记录当前层的节点数和下一层的结点数. 以上 ...

  2. 剑指 Offer 32 - I. 从上到下打印二叉树 + 层次遍历二叉树

    剑指 Offer 32 - I. 从上到下打印二叉树 Offer_32_1 题目描述 解题思路 这题属于简单题,考察的是我们对二叉树以及层次遍历的方法. 这里只需要使用简单的队列即可完成二叉树的层次遍 ...

  3. 剑指 Offer 32 - II. 从上到下打印二叉树 II

    剑指 Offer 32 - II. 从上到下打印二叉树 II 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行. 例如: 给定二叉树: [3,9,20,null,null,1 ...

  4. 剑指 Offer 32 - I. 从上到下打印二叉树

    剑指 Offer 32 - I. 从上到下打印二叉树 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印. 例如: 给定二叉树: [3,9,20,null,null,15,7], 3 ...

  5. 每日一题 - 剑指 Offer 32 - I. 从上到下打印二叉树

    题目信息 时间: 2019-06-25 题目链接:Leetcode tag:BFS(广度优先搜索) 队列 难易程度:中等 题目描述: 从上到下打印出二叉树的每个节点,同一层的节点按照从左到右的顺序打印 ...

  6. 每日一题 - 剑指 Offer 32 - II. 从上到下打印二叉树 II

    题目信息 时间: 2019-06-25 题目链接:Leetcode tag: 队列 BFS 难易程度:简单 题目描述: 从上到下按层打印二叉树,同一层的节点按从左到右的顺序打印,每一层打印到一行. 示 ...

  7. 剑指offer 23:从上往下打印二叉树

    题目描述 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 解题思路 按照从左往右从上到下的顺序打印节点,需要我们维护一个队列,这个队列放入元素的顺序是访问队头节点(起始先放入根节点),则若当前 ...

  8. 剑指offer——33分行从上到下打印二叉树

    题目描述 从上到下按层打印二叉树,同一层结点从左至右输出.每一层输出一行.   题解: 使用BFS,按层打印即可 class Solution { public: vector<vector&l ...

  9. 剑指 Offer 32 - III. 从上到下打印二叉树 III + 双端队列使用 + 蛇形打印层次遍历序列 + 正倒序输出

    剑指 Offer 32 - III. 从上到下打印二叉树 III Offer_32_3 题目详情 题解分析 本题我想的比较复杂,其实题目的要求只是需要遍历的结果逆序和正序交替,这个其实可以使用Coll ...

随机推荐

  1. C++第三十八篇 -- 研究一下Windows驱动开发(二)--WDM式驱动的加载

    基于Windows驱动开发技术详解这本书 一.简单的INF文件剖析 INF文件是一个文本文件,由若干个节(Section)组成.每个节的名称用一个方括号指示,紧接着方括号后面的就是节内容.每一行就是一 ...

  2. 自行搭建网站和APP统计平台

    做过网站运营分析的朋友,一定知道 Google 统计.友盟统计以及百度统计,它们都是非常优秀的统计平台. 但不管怎么样,数据并没有掌握在网站拥有者的手中.有时候,某些业务场景不适合使用第三方统计平台, ...

  3. netty系列之:使用POJO替代buf

    目录 简介 decode和encode 对象序列化 使用编码和解码器 总结 简介 在之前的文章中我们提到了,对于NioSocketChannel来说,它不接收最基本的string消息,只接收ByteB ...

  4. web笔记随笔

    1.Web服务组件 8.第三方内容:广告统计.mockup 7.Web前端框架: HTML5. jQuery. Bootstrap 6.Web应用: CMS. BBS. Blog 5.Web开发框架: ...

  5. C++ //关系运算符重载 < = > !=

    1 //关系运算符重载 < = > != 2 #include <iostream> 3 #include <string> 4 using namespace s ...

  6. Java知识复习回顾

    1.MVC 三层架构: M:Model 数据模型层 V:View 视图层 C:Controller控制器层 目的:解耦 2.Spring Spring:轻量级的Java开源框架,容器,目的是解决企业级 ...

  7. Spring Security中实现微信网页授权

    微信公众号提供了微信支付.微信优惠券.微信H5红包.微信红包封面等等促销工具来帮助我们的应用拉新保活.但是这些福利要想正确地发放到用户的手里就必须拿到用户特定的(微信应用)微信标识openid甚至是用 ...

  8. 终极蛇皮上帝视角之铁头娃之鲁迅之暑假闲的慌之bilibili看尚学堂网课的非洲酋长java小复习

    转自https://www.sxt.cn/Java_jQuery_in_action/eight-cache-problem.html 第一个点 自动装箱与拆箱的功能是所谓的"编译器蜜糖(C ...

  9. NOIP 模拟 7 考试总结

    T1 超级大水题,用 \(kmp\) 和 \(hash\) 均能过,但都忘了,结果只打了个暴力.难受.板子题,题解就不放了 Code #include<bits/stdc++.h> #de ...

  10. windows10磁盘分区后,如何恢复分区,回到未分区之前

    windows10磁盘分区后,恢复到分区以前的状态 1.我的电脑右键======>管理 2.找到磁盘管理 3.因为我的H盘原来是和F盘是同一个分区,只是拆分出来了,所有,找到H盘(确保数据都做过 ...