题目描述

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

题解:BFS
  1. 主要的方法与BFS写法没什么区别

  2. BFS里是每次只取一个,而我们这里先得到队列长度size,这个size就是这一层的节点个数,然后通过for循环去poll出这size个节点,这里和按行取值二叉树返回ArrayList<ArrayList<Integer>>这种题型的解法一样,之字形取值的核心思路就是通过两个方法:

    • list.add(T): 按照索引顺序从小到大依次添加

    • list.add(index, T): 将元素插入index位置,index索引后的元素依次后移,这就完成了每一行元素的倒序,或者使用Collection.reverse()方法倒序也可以

  1. public static ArrayList<ArrayList<Integer>> Print(TreeNode pRoot) {
  2. ArrayList<ArrayList<Integer>> res = new ArrayList<>();
  3. LinkedList<TreeNode> queue = new LinkedList<>();
  4. if(pRoot==null){
  5. return res;
  6. }
  7. //正序反序输出控制
  8. boolean flag=true;
  9. queue.offer(pRoot);
  10. while (queue.size()!=0){
  11. int size=queue.size();
  12. ArrayList<Integer> list = new ArrayList<>();
  13. for(int i=0;i<size;i++){
  14. TreeNode treeNode = queue.poll();
  15. if(treeNode==null){
  16. continue;
  17. }
  18. if(flag){
  19. list.add(treeNode.val);
  20. }else {
  21. list.add(0,treeNode.val);
  22. }
  23. queue.offer(treeNode.left);
  24. queue.offer(treeNode.right);
  25. }
  26. if(list.size()!=0){
  27. res.add(list);
  28. }
  29. flag=!flag;
  30. }
  31. return res;
  32. }

初始化树:

  1. public static class TreeNode {
  2. int val = 0;
  3. TreeNode left = null;
  4. TreeNode right = null;
  5. public TreeNode(int val) {
  6. this.val = val;
  7. }
  8. }
  9. private static List<TreeNode> nodeList = null;
  10. public static TreeNode createBinTree(int[] array) {
  11. nodeList=new LinkedList<TreeNode>();
  12. // 将一个数组的值依次转换为TreeNode节点
  13. for (int nodeIndex = 0; nodeIndex < array.length; nodeIndex++) {
  14. nodeList.add(new TreeNode(array[nodeIndex]));
  15. }
  16. // 对前lastParentIndex-1个父节点按照父节点与孩子节点的数字关系建立二叉树
  17. for (int parentIndex = 0; parentIndex < array.length / 2 - 1; parentIndex++) {
  18. // 左孩子
  19. nodeList.get(parentIndex).left = nodeList
  20. .get(parentIndex * 2 + 1);
  21. // 右孩子
  22. nodeList.get(parentIndex).right = nodeList
  23. .get(parentIndex * 2 + 2);
  24. }
  25. // 最后一个父节点:因为最后一个父节点可能没有右孩子,所以单独拿出来处理
  26. int lastParentIndex = array.length / 2 - 1;
  27. // 左孩子
  28. nodeList.get(lastParentIndex).left = nodeList
  29. .get(lastParentIndex * 2 + 1);
  30. // 右孩子,如果数组的长度为奇数才建立右孩子
  31. if (array.length % 2 == 1) {
  32. nodeList.get(lastParentIndex).right = nodeList
  33. .get(lastParentIndex * 2 + 2);
  34. }
  35. return nodeList.get(0);
  36. }

测试:

  1. public static void main(String[] args) {
  2. int[] tree={8,6,10,5,7,9,11};
  3. TreeNode rootNode = createBinTree(tree);
  4. ArrayList<ArrayList<Integer>> lists = Print(rootNode);
  5. System.out.println(lists);
  6. }
  7. 输出:[[8],[10,6],[5,7,9,11]]

【剑指Offer】60、按之字形顺序打印二叉树的更多相关文章

  1. 【剑指Offer】按之字形顺序打印二叉树 解题报告(Python)

    [剑指Offer]按之字形顺序打印二叉树 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-intervie ...

  2. 剑指offer系列34----按之字形顺序打印二叉树

    [题目]请实现一个函数按照之字形打印二叉树, * 即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印, * 其他行以此类推. 未优化,不是最优解,博主用的是队列 ...

  3. 剑指Offer 59. 按之字形顺序打印二叉树 (二叉树)

    题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 题目地址 https://www.nowco ...

  4. [剑指Offer] 59.按之字形顺序打印二叉树

    题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. [思路]先按层次遍历存入,通过设立标志位,将 ...

  5. 剑指offer:按之字形顺序打印二叉树(Python)

    题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 解题思路 先给定一个二叉树的样式: 前段时间 ...

  6. 剑指offer---3、按之字形顺序打印二叉树

    剑指offer---3.按之字形顺序打印二叉树 一.总结 一句话总结: |||-begin 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照 ...

  7. 剑指offer59:按之字形顺序打印二叉树:[[1], [3,2], [4,5,6,7]]

    1 题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推. 2 思路和方法 先给定一个二叉树的样式: ...

  8. 剑指offer 按之字型顺序打印二叉树

    题目描述 请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推.   使用两个栈进行存储,我们在打印某一行节点 ...

  9. 《剑指offer》从上往下打印二叉树

    本题来自<剑指offer> 从上往下打印二叉树 题目: 从上往下打印出二叉树的每个节点,同层节点从左至右打印. 思路: 队列的思想. 先将根节点加入,当取该节点时候,依次将左右子树加入,直 ...

  10. 【剑指Offer】从上往下打印二叉树 解题报告(Python)

    [剑指Offer]从上往下打印二叉树 解题报告(Python) 标签(空格分隔): 剑指Offer 题目地址:https://www.nowcoder.com/ta/coding-interviews ...

随机推荐

  1. Liunx 上安装java

    linux系统的基本指令 http://www.cnblogs.com/sxdcgaq8080/p/7470796.html ===================================== ...

  2. 详解SkipList跳跃链表【含代码】

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天继续介绍分布式系统当中常用的数据结构,今天要介绍的数据结构非常了不起,和之前介绍的布隆过滤器一样,是一个功能强大原理简单的数据结构.并且 ...

  3. HBASE手动触发major_compact

    1.定时执行脚本#!/bin/bash source /etc/profile sh ./hbase shell <<EOF major_compact 'table_name' EOF ...

  4. 外网访问oracle 很慢

    一台oracle服务器  对外网开放服务,外网连接后查询速度很慢,内网查询非常快.应该是这个cisco的防火墙有问题,查了很久 没有找到原因. 临时解决方法,在内网再建一台 跳转服务器,外网查询数据库 ...

  5. 上周 GitHub 热点速览 vol.08:系统设计必看 The System Design Primer

    作者:HelloGitHub-小鱼干 摘要:GitHub Trending 上周看点,老项目依旧抢眼,系统设计必看 Repo:The System Design Primer 周获 1k+ star, ...

  6. 大数相加-----杭电acm1002

    #include<stdio.h> #include<string.h> int main() { ], ch2[]; ], num2[]; ; scanf("%d& ...

  7. CCS过渡和动画

    过渡 过渡能让使用过渡的元素在样式发生变化时(例如鼠标划过,单击按钮,点击图片时,颜色,尺寸,位置等样式发生变化),定义变化过程中的动画,让变化不再是瞬间产生. 过渡样式使用transition定义, ...

  8. RJM8L151F6P6温度枪方案对比

    疫情当下,温度计.呼吸机.监护仪.制氧机等医疗产品的生产供应至关重要,红外温度计属于非接触式测温,它是利用物体热辐射与物体温度之间的关系来工作的. 红外测温仪是一种将红外技术与微电子技术相结合的新型温 ...

  9. Linux中screen命令

    screen是一款由GNU计划开发的用于命令行终端切换的自由软件.用户可以通过该软件同时连接多个本地或远程的命令行会话,并在其间自由切换.GNU Screen可以看作是窗口管理器的命令行界面版本.它提 ...

  10. opencv —— findContours、drawContours 寻找并绘制轮廓

    轮廓图像与 Canny 图像的区别 一个轮廓一般对应一系列的点,也就是图像中的一条曲线.轮廓图像和 Canny 图像乍看起来表现几乎是一致的,但其实组成两者的数据结构差别很大: Canny 边缘图像是 ...