题目描述
从上往下打印出二叉树的每个节点,同层节点从左至右打印。
队列
队列(queue)是只允许在一端进行插入操作,而在另一端进行删除操作的线性表。
队列是一种先进先出(First in First Out)的线性表,简称FIFO。允许插入的一端称为队尾,允许删除的一端称为队头。
Java双向队列Deque栈与队列
参考:https://blog.csdn.net/u013967628/article/details/85210036
Java中实际上提供了java.util.Stack来实现栈结构,但官方目前已不推荐使用,而是使用java.util.Deque双端队列来实现队列与栈的各种需求.如下图所示java.util.Deque的实现子类有java.util.LinkedList和java.util.ArrayDeque.顾名思义前者是基于链表,后者基于数据实现的双端队列.
总体介绍
要讲栈和队列,首先要讲Deque接口。Deque的含义是“double ended queue”,即双端队列,它既可以当作栈使用,也可以当作队列使用。下表列出了Deque与Queue相对应的接口:
下表列出了Deque与Stack对应的接口:
package tree;
import java.util.*;
/*
从上往下打印二叉树
从上往下打印出二叉树的每个节点,同层节点从左至右打印。(广度优先遍历)
*/
public class PrintFromTopToBottom_22 {
public ArrayList<Integer> PrintFromTopToBottom(TreeNode_22 root) {
Deque<TreeNode_22> deque = new LinkedList<TreeNode_22>();
ArrayList<Integer> res = new ArrayList<Integer>();
if (root == null) {
return res;
}
deque.add(root);
while (!deque.isEmpty()) {
//getFirst检索第一个元素
TreeNode_22 node = deque.getFirst();
//pollFirst检索并删除此deque的第一个元素,如果此deque为空,则返回 null 。
deque.pollFirst();
res.add(node.val);
if (node.left != null) {
//addLast在deque的末尾插入指定的元素
deque.addLast(node.left);
}
if (node.right != null) {
deque.addLast(node.right);
}
}
return res;
}
public ArrayList<Integer> PrintFromTopToBottom1(TreeNode_22 root) {
Queue<TreeNode_22> queue = new LinkedList<TreeNode_22>();
ArrayList<Integer> res = new ArrayList<Integer>();
if (root == null) {
return res;
}
queue.add(root);
while (!queue.isEmpty()) {
//getFirst检索第一个元素
TreeNode_22 node = queue.element();
//pollFirst检索并删除此deque的第一个元素,如果此deque为空,则返回 null 。
queue.poll();
res.add(node.val);
if (node.left != null) {
//addLast在deque的末尾插入指定的元素
queue.add(node.left);
}
if (node.right != null) {
queue.add(node.right);
}
}
return res;
}
public static void main(String[] args) {
TreeNode_22 root = new TreeNode_22(8);
root.left = new TreeNode_22(6);
root.right = new TreeNode_22(10);
root.left.left = new TreeNode_22(5);
root.left.right = new TreeNode_22(7);
root.right.left = new TreeNode_22(9);
root.right.right = new TreeNode_22(11);
PrintFromTopToBottom_22 pftt = new PrintFromTopToBottom_22();
ArrayList<Integer> arrayList = pftt.PrintFromTopToBottom1(root);
//ArrayList遍历
System.out.println("1.for循环的遍历方式:");
for (int i = 0; i < arrayList.size(); i++) {
System.out.println(arrayList.get(i));
}
System.out.println("2.foreach的遍历方式:");
for (Integer index : arrayList) {
System.out.println(index);
}
System.out.println("3.Iterator的遍历方式:");
Iterator<Integer> iterator = arrayList.iterator();
while (iterator.hasNext()) {
System.out.println(iterator.next());
}
}
}