news 2026/7/4 10:31:25

使用两个队列实现一个栈

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
使用两个队列实现一个栈

在 Java 中,利用两个队列实现栈的核心思路是通过队列的“先进先出”特性模拟栈的“后进先出”特性:始终让一个队列(记为queue1)存储栈的所有元素,另一个队列(记为queue2)作为临时中转。以下是完整的实现思路和代码示例:

核心原理

  1. 入栈(push):直接将元素添加到主队列queue1
  2. 出栈(pop):将queue1中除最后一个元素外的所有元素依次转移到queue2,弹出queue1中剩余的最后一个元素(即栈顶元素),然后交换queue1queue2的角色(让queue2变为空的中转队列)。
  3. 获取栈顶(peek):逻辑与pop类似,但转移后不弹出最后一个元素,而是记录其值后再将其转移到queue2,最后交换队列角色。
  4. 判空(isEmpty):直接判断主队列queue1是否为空。

完整代码实现

import java.util.LinkedList; import java.util.Queue; /** * 用两个队列实现栈 */ public class StackByTwoQueues { // 主队列:存储栈的所有元素 private Queue<Integer> queue1; // 临时中转队列 private Queue<Integer> queue2; // 初始化 public StackByTwoQueues() { // 推荐使用LinkedList作为Queue的实现(LinkedList实现了Deque,支持队列操作) queue1 = new LinkedList<>(); queue2 = new LinkedList<>(); } /** * 入栈:直接添加到主队列 * @param x 要入栈的元素 */ public void push(int x) { queue1.offer(x); } /** * 出栈:弹出栈顶元素(最后入队的元素) * @return 栈顶元素 * @throws RuntimeException 栈为空时抛出异常 */ public int pop() { if (isEmpty()) { throw new RuntimeException("栈为空,无法执行pop操作"); } // 将queue1中除最后一个元素外的所有元素转移到queue2 while (queue1.size() > 1) { queue2.offer(queue1.poll()); } // 弹出queue1中剩余的最后一个元素(栈顶) int top = queue1.poll(); // 交换两个队列的角色:让queue1重新作为主队列,queue2为空 Queue<Integer> temp = queue1; queue1 = queue2; queue2 = temp; return top; } /** * 获取栈顶元素(不弹出) * @return 栈顶元素 * @throws RuntimeException 栈为空时抛出异常 */ public int peek() { if (isEmpty()) { throw new RuntimeException("栈为空,无法执行peek操作"); } // 逻辑同pop,但保留最后一个元素 while (queue1.size() > 1) { queue2.offer(queue1.poll()); } int top = queue1.peek(); // 将最后一个元素也转移到queue2 queue2.offer(queue1.poll()); // 交换队列角色 Queue<Integer> temp = queue1; queue1 = queue2; queue2 = temp; return top; } /** * 判断栈是否为空 * @return 空返回true,否则返回false */ public boolean isEmpty() { return queue1.isEmpty(); } // 测试示例 public static void main(String[] args) { StackByTwoQueues stack = new StackByTwoQueues(); // 入栈:1 -> 2 -> 3 stack.push(1); stack.push(2); stack.push(3); // 输出栈顶:3 System.out.println("栈顶元素:" + stack.peek()); // 出栈:3 System.out.println("出栈元素:" + stack.pop()); // 输出栈顶:2 System.out.println("栈顶元素:" + stack.peek()); // 出栈:2 System.out.println("出栈元素:" + stack.pop()); // 出栈:1 System.out.println("出栈元素:" + stack.pop()); // 判空:true System.out.println("栈是否为空:" + stack.isEmpty()); } }

代码说明

  1. 队列选择:使用LinkedList实现Queue接口(LinkedList支持队列的offer/poll/peek操作,效率高)。
  2. 异常处理poppeek操作时,若栈为空则抛出运行时异常,符合栈的常规行为。
  3. 队列交换:每次pop/peek后交换queue1queue2的引用,避免重复创建队列,节省内存。

时间复杂度

  • push:O(1)(直接入队)。
  • pop/peek:O(n)(需要转移 n-1 个元素,n 为栈的大小)。

优化思路(可选)

若希望降低pop/peek的时间复杂度,可改用一个队列 + 记录栈顶的方式:

  • 入栈时直接入队,并记录栈顶。
  • 出栈时,将队列前 n-1 个元素依次出队并重新入队,最后弹出第 n 个元素(栈顶)。
    这种方式仅需一个队列,核心逻辑与双队列一致,但代码更简洁。
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/7/4 9:55:01

淘宝秒杀系统架构实战 - 百万级并发技术方案

一、业务场景分析1.1 秒杀特点瞬时流量: 开场10秒内100万请求读写比例: 1000:1 (99.9%用户抢不到)库存稀缺: 1000件商品,100万人抢强一致性: 不能超卖,不能少卖用户体验: P99延迟 < 200ms1.2 核心技术挑战100万并发 ↓网关层(5万) 应用层(2万) 数据层(1万)如何削峰? 如何防…

作者头像 李华
网站建设 2026/7/3 18:47:20

kotaemon本地化隐私保护方案详解

Kotaemon本地化隐私保护方案详解 在AI技术加速渗透企业核心业务的当下&#xff0c;一个尖锐的问题摆在开发者面前&#xff1a;如何在享受大模型智能红利的同时&#xff0c;守住数据安全的生命线&#xff1f;尤其对于金融、医疗等敏感行业&#xff0c;哪怕是最细微的数据外泄风险…

作者头像 李华
网站建设 2026/7/3 17:57:20

Python爬虫实战:基于异步技术的大宗商品期货交易数据爬取与趋势分析

引言:期货数据爬虫的重要性与挑战 在当今数字化金融时代,期货市场交易数据已成为投资者、分析师和研究人员进行大宗商品价格趋势分析的关键资源。期货数据不仅反映了市场供需关系,还包含了宏观经济、政策变化和全球事件的影响。然而,获取高质量、实时的期货交易数据面临着…

作者头像 李华
网站建设 2026/7/3 8:47:42

46、Linux使用指南:从基础到高级的全面攻略

Linux使用指南:从基础到高级的全面攻略 一、Linux基础概念 1.1 “Free”的含义 在特定语境中,“free”指的是自由或自主,而非价格层面的免费。这种区别在相关介绍中会有详细解释。 1.2 Unix的起源 “Unix”最初写作“Unics”,代表“Uniplex Information and Computing…

作者头像 李华
网站建设 2026/7/4 7:57:19

LobeChat能否用于生成广告语?品牌传播创意工厂

LobeChat能否用于生成广告语&#xff1f;品牌传播创意工厂 在品牌营销的战场上&#xff0c;一句精准有力的广告语&#xff0c;往往能撬动千万级的市场认知。然而&#xff0c;传统创意流程依赖少数“天才文案”&#xff0c;不仅成本高昂&#xff0c;且难以规模化响应快速变化的消…

作者头像 李华
网站建设 2026/7/3 3:56:57

Windows下TensorFlow 2.5 GPU环境配置指南

Windows下TensorFlow 2.5 GPU环境配置实战指南 在深度学习项目中&#xff0c;训练一个大型模型动辄需要数小时甚至几天。如果你还在用CPU跑TensorFlow&#xff0c;那可能连“调参侠”的门槛都还没迈进去——等你调完一组超参数&#xff0c;别人已经跑完三轮实验了。 真正高效…

作者头像 李华