当前位置:首页 > IT技术 > 编程语言 > 正文

JAVA:使用栈实现一个队列
2021-10-27 14:41:41

使用栈实现一个队列,需要弄清楚栈和队列的区别:

栈:先进后出;

队列:先进先出。

实现思路:

1)通过两个栈(pushStack / popStack)对倒,确保 popStack 栈的出栈顺序与队列出列一致。

2)核心难点在加入队列操作,假设队列中已经加入1、2、3、4,加入5的过程:

2.1)假设已经加入1/2/3/4

2.2)把popStack中的数据导入pushStack

2.3)pushStack加入5

2.4)把pushStack中的数据导入popStack

流程示意图如下:

JAVA:使用栈实现一个队列_数据导入

实现代码:

import java.util.Stack;

public class QueueWithStack<T> {
    /**
     * Test 测试代码
     */
    public static void main(String[] args) {
        QueueWithStack<Integer> queue = new QueueWithStack<>();
        queue.add(1);
        System.out.println("入队列:1");
        queue.add(2);
        System.out.println("入队列:2");
        queue.add(3);
        System.out.println("入队列:3");
        queue.add(4);
        System.out.println("入队列:4");

        System.out.println("出队列:" + queue.pop());
        System.out.println("出队列:" + queue.pop());
        
        queue.add(5);    
        System.out.println("入队列:5");
        queue.add(6);
        System.out.println("入队列:6");
        System.out.println("====================");
        while (false == queue.isEmpty()) {
            System.out.println("出队列:" + queue.pop());
        }

        System.out.println("队列内元素个数:" + queue.size());
    }

    // 入栈是,将数据写入该集合,然后在推向pop集合。
    private Stack<T> pushStack = null;
    // 出站时,读取该集合
    private Stack<T> popStack = null;

    public QueueWithStack() {
        pushStack = new Stack<>();
        popStack = new Stack<>();
    }

    public boolean isEmpty() {
        return popStack.isEmpty();
    }

    public int size() {
        return popStack.size();
    }

    public void add(T t) {
        while (false == popStack.isEmpty()) {
            T val = popStack.pop();
            pushStack.push(val);
        }

        pushStack.add(t);

        while (false == pushStack.isEmpty()) {
            T val = pushStack.pop();
            popStack.push(val);
        }

    }

    /**
     * 从队列中取出数据,并从队列中移除数据
     */
    public T pop() {
        if (isEmpty()) {
            throw new RuntimeException("Queue is empty.");
        }
        return popStack.pop();
    }

    /**
     * 获取栈顶元素,但不会从队列中移除数据
     */
    public T peek() {
        if (isEmpty()) {
            throw new RuntimeException("Queue is empty.");
        }
        return popStack.peek();
    }
}

打印结果:

入队列:1
入队列:2
入队列:3
入队列:4
出队列:1
出队列:2
入队列:5
入队列:6
====================
出队列:3
出队列:4
出队列:5
出队列:6
队列内元素个数:0

 

基础才是编程人员应该深入研究的问题,比如:
1)List/Set/Map内部组成原理|区别
2)mysql索引存储结构&如何调优/b-tree特点、计算复杂度及影响复杂度的因素。。。
3)JVM运行组成与原理及调优
4)Java类加载器运行原理
5)Java中GC过程原理|使用的回收算法原理
6)Redis中hash一致性实现及与hash其他区别
7)Java多线程、线程池开发、管理Lock与Synchroined区别
8)Spring IOC/AOP 原理;加载过程的。。。
+加关注】。

本文摘自 :https://blog.51cto.com/u

开通会员,享受整站包年服务立即开通 >