【✅面试编程题:如何用队列实现一个栈】

✅面试编程题:如何用队列实现一个栈

💡典型回答

使用两个队列可以实现一个栈,一个队列用来存储栈中的元素,另一个队列用来在pop操作时暂存元素。

上才艺:

import java.util.LinkedList;
import java.util.Queue;

public class MyStack<T> {
   
    private Queue<T> queue; // 主队列
    private Queue<T> tempQueue; // 辅助队列

    public MyStack() {
   
        queue = new LinkedList<>();
        tempQueue = new LinkedList<>();
    }

    // 添加元素到栈顶
    public void push(T element) {
   
        queue.offer(element);
    }

    // 弹出栈顶元素并返回
    public T pop() {
   
        if (isEmpty()) {
   
            throw new RuntimeException("stack is empty");
        }
        // 将主队列中除了最后一个元素外的所有元素移到辅助队列中
        while (queue.size() > 1) {
   
            tempQueue.offer(queue.poll());
        }
        T element = queue.poll(); // 获取最后一个元素
        Queue<T> temp = queue; // 交换主队列和辅助队列的引用
        queue = tempQueue;
        tempQueue = temp;
        return element;
    }

    // 获取栈顶元素但不弹出
    public T peek() {
   
        if (isEmpty()) {
   
            throw new RuntimeException("stack is empty");
        }
        // 将主队列中除了最后一个元素外的所有元素移到辅助队列中
        while (queue.size() > 1) {
   
            tempQueue.offer(queue.poll());
        }
        T element = queue.poll(); // 获取最后一个元素
        tempQueue.offer(element); // 将最后一个元素放回主队列
        Queue<T> temp = queue; // 交换主队列和辅助队列的引用
        queue = tempQueue;
        tempQueue = temp;
        return element;
    }

    // 判断栈是否为空
    public boolean isEmpty() {
   
        return queue.isEmpty();
    }
}

其中,push方法用来入栈,直接将元素加入queue队列中。

pop方法用来出栈,先将queue队列中的元素倒入tempQueue队列中,直到queue队列中只有一个元素,将其弹出即可。

peek方法用来获取栈顶元素,与pop方法类似,只是在弹出元素之前需要先将其加入tempQueue队列中

isEmpty方法用来判断栈是否为空,如果queue队列为空,则栈为空。

这个实现的时间复杂度为O(n),空间复杂度为O(n),其中n为栈中元素的个数。

相关推荐

  1. 面试编程如何队列实现一个

    2023-12-15 08:12:04       40 阅读
  2. 面试算法-119-实现队列

    2023-12-15 08:12:04       14 阅读
  3. 面试算法-118-队列实现

    2023-12-15 08:12:04       20 阅读
  4. 剑指offer面试7 俩个实现队列

    2023-12-15 08:12:04       36 阅读
  5. 实现队列

    2023-12-15 08:12:04       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-15 08:12:04       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-15 08:12:04       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-15 08:12:04       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-15 08:12:04       20 阅读

热门阅读

  1. AUTOSAR从入门到精通-中间件通信DDS(一)

    2023-12-15 08:12:04       43 阅读
  2. Ubuntu无法解析域名DNS指向127.0.0.53问题处理

    2023-12-15 08:12:04       42 阅读
  3. CAN总线协议

    2023-12-15 08:12:04       26 阅读
  4. SQL信息系统 - 客观题复习

    2023-12-15 08:12:04       38 阅读
  5. React Hooks学习指北

    2023-12-15 08:12:04       34 阅读
  6. 某60内网渗透之利用iodine构建专属dns隧道

    2023-12-15 08:12:04       33 阅读
  7. cfa一级考生复习经验分享系列(二)

    2023-12-15 08:12:04       32 阅读
  8. 在Go中理解栈和先进先出原则

    2023-12-15 08:12:04       40 阅读