用两个栈实现队列(Java实现)

这篇博客介绍了如何利用两个栈的特性来模拟队列的先进先出(FIFO)行为。通过将一个栈用于插入元素(appendTail),另一个栈用于删除元素(deleteHead),在删除元素时如果第二个栈为空,则将第一个栈的所有元素转移到第二个栈,从而确保了队列的操作。这种方法巧妙地解决了栈的后进先出(LIFO)特性与队列需求的冲突。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

用两个栈实现队列


题目

剑指 Offer 09. 用两个栈实现队列

用两个栈实现一个队列。队列的声明如下,请实现它的两个函数 appendTail 和 deleteHead ,分别完成在队列尾部插入整数和在队列头部删除整数的功能。(若队列中没有元素,deleteHead 操作返回 -1 )

分析

想要用栈实现队列。我们先来回忆一下栈和队列的区别:

  1. 栈的特点是先进后出。
  2. 队列的特点是先进先出。

怎么能让先进后出的队列,来管理先进先出的数据呢?

答案是再增加一个队列,先进后出2次,数据就变为了先进先出了。我们用一个栈s1来添加数据,用另一个栈s2来弹出数据,当s2为空时,把s1的数据转移到s2即可。

代码实现

    /**
     * 剑指 Offer 09. 用两个栈实现队列
     */
    class CQueue {
        private Stack<Integer> s1;
        private Stack<Integer> s2;


        public CQueue() {
            s1 = new Stack();
            s2 = new Stack();
        }

        public void appendTail(int value) {
            s1.push(value);
        }

        public int deleteHead() {
            if (s2.isEmpty()){
                while(!s1.isEmpty()) {
                    s2.push(s1.pop());
                }
            }
            return s2.isEmpty() ? -1 : s2.pop();
        }
    }
### 使用两个实现队列Java代码示例 通过使用两个来模拟队列的行为是一种常见的数据结构设计方法。以下是基于此逻辑的一个具体实现: #### 实现原理 为了使两个能够完成队列的功能,可以定义一个输入 `inStack` 和一个输出 `outStack`。当执行入队操作时,元素被压入 `inStack`;而当需要出队时,则将所有元素从 `inStack` 转移到 `outStack` 并弹出顶部元素。 ```java import java.util.Stack; class MyQueue { private Stack<Integer> inStack; private Stack<Integer> outStack; /** Initialize your data structure here. */ public MyQueue() { inStack = new Stack<>(); outStack = new Stack<>(); } /** Push element x to the back of queue. */ public void push(int x) { inStack.push(x); } /** Removes the element from in front of queue and returns that element. */ public int pop() { if (outStack.isEmpty()) { while (!inStack.isEmpty()) { outStack.push(inStack.pop()); } } return outStack.pop(); } /** Get the front element. */ public int peek() { if (outStack.isEmpty()) { while (!inStack.isEmpty()) { outStack.push(inStack.pop()); } } return outStack.peek(); } /** Returns whether the queue is empty. */ public boolean empty() { return inStack.isEmpty() && outStack.isEmpty(); } } ``` 上述代码展示了如何利用两个来构建一个基本的队列功能[^1]。其中的关键在于理解何时以及如何在两个之间转移数据以保持 FIFO 的顺序。 #### 测试用例 下面是一个简单的测试例子用于验证该类的工作情况: ```java public class Main { public static void main(String[] args) { MyQueue obj = new MyQueue(); obj.push(1); obj.push(2); System.out.println(obj.peek()); // 输出 1 System.out.println(obj.pop()); // 输出 1 System.out.println(obj.empty()); // 输出 false } } ``` 这段程序创建了一个新的队列对象并进行了几个基础的操作演示其行为是否符合预期[^2]。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

卜大爷

觉得不错的可以给我加油哦

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值