JAVA:使用栈实现一个队列
使用栈实现一个队列,需要弄清楚栈和队列的区别:
栈:先进后出;
队列:先进先出。
实现思路:
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
流程示意图如下:

实现代码:
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
JAVA:使用栈实现一个队列的更多相关文章
- java两个栈实现一个队列&&两个队列实现一个栈
栈:先进后出 队列:先进先出 两个栈实现一个队列: 思路:先将数据存到第一个栈里,再将第一个栈里的元素全部出栈到第二个栈,第二个栈出栈,即可达到先进先出 源码: class Queue<E&g ...
- Python两个栈实现一个队列
牛客网原题: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 实现这个算法的方式有很多种,这里就写一种比较简单易懂的:虽然可能算法和效率上不太出色,当大多数人 ...
- web前端面试系列 - 数据结构(两个栈模拟一个队列)
一. 用两个栈模拟一个队列 思路一: 1. 一个栈s1作为数据存储,另一个栈s2,作为临时数据存储. 2. 入队时将数据压人s1 3. 出队时将s1弹出,并压人s2,然后弹出s2中的顶部数据,最后再将 ...
- python两个队列实现一个栈和两个栈实现一个队列
1.两个栈实现一个队列 两个栈stack1和stack2, push的时候直接push进stack1,pop时需要判断stack1和stack2中的情况.如果stack2不为空的话,直接从stack2 ...
- python---两个栈实现一个队列
class Solution: """两个栈实现一个队列""" def __init__(self): # 接收栈 self.accept_ ...
- 剑指offer(五):用两个栈实现一个队列
题目: 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 解决办法: 队列先进先出,栈先进后出(stack1和stack2) 其实主要要注意的点是: ①在添加时直接 ...
- 两个栈实现一个队列,C语言实现,队列可伸缩,容纳任意数目的元素。
一.思路:1.创建两个空栈A和B:2.A栈作为队列的入口,B栈作为队列的出口:3.入队列操作:即是入栈A:4.出队列操作:若栈B为空,则将A栈内容出栈并压人B栈,再出 B栈:不为空就直接出栈: 二.代 ...
- 剑指offer:用两个栈实现一个队列
题目 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 解题思路 用一个栈A来保存入栈,当要出栈的时候,将栈A的元素按照栈后进先出的特点转移到栈B中(此时栈A为空了 ...
- 用两个栈实现一个队列(C++)
分析 栈:后进先出 队列:先进先出 要使用两个栈实现队列(先进先出),主要思路是 1.插入一个元素:直接将元素插入stack1即可. 2.删除一个元素:当stack2不为空时 ,直接弹出栈顶元素,当s ...
随机推荐
- jhipster技术栈研究
背景: 公司新的微服务项目都用jhipster脚手架来开发,这篇博客是jhipster里面涉及到技术的汇总目录 一.官方文档中涉及到的技术栈 前端技术栈 Angular / React / Vue R ...
- PHP控制结构if else,while,do while,for,foreach,break ,continue
php中控制结构有 控制结构 判断分支 if else, 三元运算符, switch case, 循环 while do while for foreach 跳出 break continue // ...
- 常用的PHP字符串操作函数
1.strlen 但是要注意!如果字符串中是汉字等其他字符时候呢? $str = "我"; echo strlen($str); //一个汉字,在UTF8格式下,显示3, ANSI ...
- QQ推广工具
目前比较简单易用的QQ推广工具有:一键加群.在线聊天 一.一键加群 1.官网链接 http://qun.qq.com/join.html 2.使用 1登录自己的QQ 2创建一个想要作为推广的群 3选择 ...
- Gradle 使用教程之 Task 详解
最近打算学习下 gradle 在 Android 中的使用,结果百度出来的文章都是介绍性文章,没啥干货.后来找到 gradle 官网教程,自己对着撸. Gradle 概述: Gradle 是一个基于 ...
- 新建本地用户连接vsftp出现530 Login incorrect
新建的用户的方式 [root@centos2 /var/ftp]# useradd -s /sbin/nologin user1 出错原因: /etc/pam.d/vsftp文件作了限制 [root@ ...
- MySQL/MariaDB数据库的各种日志管理
MySQL/MariaDB数据库的各种日志管理 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.事务日志 (transaction log) 1>.Innodb事务日志相 ...
- Layui外部js修改表格内容
//测试修改数据的方法! var _tds=$(".layui-table-body.layui-table-main:eq(1) tr:eq(1)").children(); _ ...
- 《TensorFlow2深度学习》学习笔记(二)手动搭建并测试简单神经网络(附mnist.npz下载方式)
本实验使用了mnist.npz数据集,可以使用在线方式导入,但是我在下载过程中老是因为网络原因被打断,因此使用离线方式导入,离线包已传至github方便大家下载: https://github.com ...
- [AI] 论文笔记 - U-Net 简单而又接近本质的分割网络
越简单越接近本质. 参考资料 U-Net: Convolutional Networks for Biomedical Image Segmentation Abstract & Introd ...