从上往下打印二叉树_22

题目描述

从上往下打印出二叉树的每个节点,同层节点从左至右打印。

队列

队列(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());
        }
    }
}

 

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章