使用两个队列实现栈

在计算机科学中,栈是一种数据结构,它遵循后进先出(LIFO)的原则。这意味着最后一个被添加到栈的元素将是第一个被移除的元素。然而,Java的标准库并没有提供栈的实现,但我们可以使用两个队列来模拟一个栈的行为。

首先,我们需要创建一个名为MyStack的类,该类包含两个栈:queue1queue2。这两个栈将用于实现队列的功能。接下来,我们需要实现队列的基本操作,包括pushpoppeekempty

首先,我们需要创建一个栈类 

public class MyStack {
    Queue<Integer> queue1;
    Queue<Integer> queue2;

    public MyStack(){
        queue1 = new LinkedList<>();
        queue2 = new LinkedList<>();
    }
}

push方法

push(int value): 将一个元素添加到栈中。首先,我们将该元素添加到queue2中。然后,我们将queue1中的所有元素移动到queue2中,直到queue1为空。最后,我们交换queue1queue2的角色,使得queue1始终是栈顶元素所在的队列。

public void push(int value){
        queue2.offer(value);
        while (!queue1.isEmpty()){
            queue2.offer(queue1.poll());
        }
        Queue<Integer> temp = queue1;
        queue1 = queue2;
        queue2 = temp;
    }

pop方法

pop(): 从栈中移除并返回栈顶元素。由于栈顶元素位于queue1中,我们只需调用queue1.poll()即可。

public int pop(){
        return queue1.poll();
    }

top()方法

top(): 返回栈顶元素但不将其从栈中移除。由于栈顶元素位于queue1中,我们只需调用queue1.peek()即可。

public int top(){
        return queue1.peek();
    }

isEmpty方法

isEmpty(): 检查栈是否为空。我们只需检查queue1是否为空即可。

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

完整代码

public class MyStack {
    Queue<Integer> queue1;
    Queue<Integer> queue2;

    public MyStack(){
        queue1 = new LinkedList<>();
        queue2 = new LinkedList<>();
    }

    public void push(int value){
        queue2.offer(value);
        while (!queue1.isEmpty()){
            queue2.offer(queue1.poll());
        }
        Queue<Integer> temp = queue1;
        queue1 = queue2;
        queue2 = temp;
    }
    public int pop(){
        return queue1.poll();
    }

    public int top(){
        return queue1.peek();
    }

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

}

测试类

public class Test {
    public static void main(String[] args) {
        MyStack myStack = new MyStack();
        System.out.println(myStack.isEmpty());  // true
        myStack.push(1);
        myStack.push(2);
        myStack.push(3);
        System.out.println(myStack.pop()); // 3
        System.out.println(myStack.pop()); // 2
        System.out.println(myStack.isEmpty()); // false
        System.out.println(myStack.pop()); // 1
        System.out.println(myStack.isEmpty()); // true
    }
}

运行结果

相关推荐

  1. 实现队列(c++实现

    2024-02-23 09:32:07       55 阅读
  2. 刷题——利用实现队列

    2024-02-23 09:32:07       26 阅读
  3. 225.队列实现

    2024-02-23 09:32:07       31 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-02-23 09:32:07       94 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-02-23 09:32:07       100 阅读
  3. 在Django里面运行非项目文件

    2024-02-23 09:32:07       82 阅读
  4. Python语言-面向对象

    2024-02-23 09:32:07       91 阅读

热门阅读

  1. 前端常见面试题之react基础

    2024-02-23 09:32:07       47 阅读
  2. django rest framework 学习笔记-实战商城3

    2024-02-23 09:32:07       61 阅读
  3. 在jar里限制指定的包名才可调用(白名单)。

    2024-02-23 09:32:07       55 阅读
  4. 汽车信息安全--S32K3的HSE如何与App Core通信(1)?

    2024-02-23 09:32:07       47 阅读
  5. CentOS 7.x 使用 RPM 包安装 Gitlab

    2024-02-23 09:32:07       47 阅读
  6. 删除有序数组中的重复项

    2024-02-23 09:32:07       57 阅读
  7. proguard 混淆jar内容

    2024-02-23 09:32:07       56 阅读
  8. 机器学习是什么

    2024-02-23 09:32:07       50 阅读
  9. Python 进阶语法:enum(枚举)

    2024-02-23 09:32:07       51 阅读
  10. 4.Snapkit的使用

    2024-02-23 09:32:07       53 阅读
  11. Hadoop-Yarn-NodeManager是如何启动容器的

    2024-02-23 09:32:07       52 阅读
  12. -bash: /root/.ssh/authorized_keys: Read-only file system

    2024-02-23 09:32:07       49 阅读