← 返回首页
JavaSE系列教程(四十九)
发表时间:2020-02-01 14:58:29
讲解集合框架之Stack和Queue.

Stack类和Queue接口,分别对应数据结构中的栈和队。栈:后进先出(Last In First Out(LIFO)),由List接口实现。队:先进先出(First In First Out(FIFO)),由Queue接口实现。

栈与队列的相同点:
1. 都是线性结构。
2. 插入操作都是限定在表尾进行。
3. 都可以通过顺序结构和链式结构实现。
4. 插入与删除的时间复杂度都是O(1),在空间复杂度上两者也一样。
5. 多链栈和多链队列的管理模式可以相同

栈与队列的不同点:
1. 删除数据元素的位置不同,栈的删除操作在表尾进行,队列的删除操作在表头进行。
2. 应用场景不同;
常见栈的应用场景包括括号问题的求解,表达式的转换和求值,函数调用和递归实现,深度优先搜索遍历等;
常见的队列的应用场景包括计算机系统中各种资源的管理,消息缓冲器的管理和广度优先搜索遍历等。
3. 顺序栈能够实现多栈空间共享,而顺序队列不能。

1.Stack

实例:

        Stack stack = new Stack();
        //入栈
        stack.push(12);
        stack.push(18);
        stack.push(7);
        stack.push(22);
        stack.push(34);

        //当栈不为空的情况下,出栈。
        while (!stack.isEmpty()) {
             System.out.println(stack.pop()); //取栈顶元素,并且弹出。
        }

运行结果:
34
22
7
18
12

2.Queue

实例:

        Queue queue = new LinkedList();

        queue.add(12); //add 入队
        queue.add(8);
        queue.add(20);
        queue.add(34);
        queue.add(18);

        while (!queue.isEmpty()) {
            System.out.println(queue.poll()); //出队
        }

运行结果:
12
8
20
34
18

综合实例

使用Stack实现十进制转换为二进制。

public class NumberConvertDemo {

    public static void main(String[] args) {

        int num = 20; //将num转成二进制数。
        Stack stack = new Stack(); //用来存放余数的结果。
        while(num!=0){
            stack.push(num%2); //把余数压入栈
            num/=2;
        }

        //出栈的结果就是二进制的结果。
        while(!stack.isEmpty()){
            System.out.print(stack.pop());
        }
    }
}

运行结果:
10100