剑指offer---3、按之字形顺序打印二叉树
一、总结
一句话总结:
|||-begin
请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。
|||-end
可以先快速把所有题目过一遍,先主干,后枝叶
考点就是树的层次遍历
1、如何解决效率低的问题(将每层的数据存进ArrayList中,偶数层时进行reverse操作,在海量数据时,这样效率太低了)?
思路:利用Java中的LinkedList的底层实现是双向链表的特点。
可双向遍历,奇数层时从前向后遍历,偶数层时从后向前遍历
二、内容在总结中
1、相关知识
请实现一个函数按照之字形打印二叉树,即第一行按照从左到右的顺序打印,第二层按照从右至左的顺序打印,第三行按照从左到右的顺序打印,其他行以此类推。
2、代码
/** * 大家的实现很多都是将每层的数据存进ArrayList中,偶数层时进行reverse操作, * 在海量数据时,这样效率太低了。 * * 下面的实现:不必将每层的数据存进ArrayList中,偶数层时进行reverse操作,直接按打印顺序存入 * 思路:利用Java中的LinkedList的底层实现是双向链表的特点。 * 1)可用做队列,实现树的层次遍历 * 2)可双向遍历,奇数层时从前向后遍历,偶数层时从后向前遍历 */ public ArrayList<ArrayList<Integer> > Print(TreeNode pRoot) { ArrayList<ArrayList<Integer>> ret = new ArrayList<>(); if (pRoot == null) { return ret; } ArrayList<Integer> list = new ArrayList<>(); LinkedList<TreeNode> queue = new LinkedList<>(); queue.addLast(null);//层分隔符 queue.addLast(pRoot); boolean leftToRight = true; while (queue.size() != 1) { TreeNode node = queue.removeFirst(); if (node == null) {//到达层分隔符 Iterator<TreeNode> iter = null; if (leftToRight) { iter = queue.iterator();//从前往后遍历 } else { iter = queue.descendingIterator();//从后往前遍历 } leftToRight = !leftToRight; while (iter.hasNext()) { TreeNode temp = (TreeNode)iter.next(); list.add(temp.val); } ret.add(new ArrayList<Integer>(list)); list.clear(); queue.addLast(null);//添加层分隔符 continue;//一定要continue } if (node.left != null) { queue.addLast(node.left); } if (node.right != null) { queue.addLast(node.right); } } return ret; }