【剑指Offer面试编程题】题目1512:用两个栈实现队列--九度OJ
2024-10-08 13:11:02
- 题目描述:
-
用两个栈来实现一个队列,完成队列的Push和Pop操作。
队列中的元素为int类型。
- 输入:
-
每个输入文件包含一个测试样例。
对于每个测试样例,第一行输入一个n(1<=n<=100000),代表队列操作的个数。
接下来的n行,每行输入一个队列操作:
1. PUSH X 向队列中push一个整数x(x>=0)
2. POP 从队列中pop一个数。
- 输出:
-
对应每个测试案例,打印所有pop操作中从队列pop中的数字。如果执行pop操作时,队列为空,则打印-1。
样例输入:
3
PUSH 10
POP
POP
样例输出:
10
-1
【解题思路】新建栈st1模拟队列的输入,只要遇到push操作,都将元素压入st1中。另外,新建栈st2模拟队列的输出,如果pop操作时,先判断st1是否为空,当st2为空,则将st1的中的所有元素挨个弹出并压入st2中以备输出,这时的st2中的元素的排列正好是当前所有元素的输入的逆序,符合队列的输出顺序;-->>当出现pop操作时,如果st2不为空,这个时候的栈顶元素真好是当前状态的队列的头元素,则直接弹出栈顶元素作为队列的输出。
AC
code:
#include <cstdio>
#include <stack>
using namespace std; int main()
{
int n;
scanf("%d",&n);
stack<int> st1,st2;
for(int i=0;i<n;++i)
{
char cc[5];
int tt;
scanf("%s",cc);
if(cc[1]=='U')
{
scanf("%d",&tt);
st1.push(tt);
}else
{
if(st2.empty())
{
while(!st1.empty())
{
int te=st1.top();
st2.push(te);
st1.pop();
}
}
if(st2.empty())
{
printf("-1\n");
continue;
}
int te=st2.top();
printf("%d\n",te);
st2.pop();
}
}
return 0;
}
/**************************************************************
Problem: 1512
User: huo_yao
Language: C++
Result: Accepted
Time:60 ms
Memory:1656 kb
****************************************************************/
题目链接:http://ac.jobdu.com/problem.php?pid=1512
最新文章
- 菜鸟学Linux命令:lsof命令 查找指定用户、进程、端口打开的文件
- android 修改framework下资源文件后如何编译
- struts的hello world小试
- JAVA继承时this和super关键字
- Java [Leetcode 205]Isomorphic Strings
- 【高级JEE技术】JMX
- Android_HTML解析器_jsoup
- AndroidStudio项目移植到Eclipse
- 精讚部落::MySQL 的MEMORY engine
- itmacy_我的博客
- 深入浅出Hadoop之HDFS
- LVS实现负载均衡安装配置详解
- mybatis入门篇:代码生成器(MyBatis Generator)
- Linux chattr和lsattr命令使用方法
- 示例:pm_multiple_models 匹配——形状匹配
- vue.js安装问题
- 发送短信验证码倒计时,CountDownTimer;
- CentOS增加用户到sudo用户组
- HBase Rowkey的散列与预分区设计
- 快速上手最棒的网格框架ag-Grid
热门文章
- ASP.NET Core搭建多层网站架构【4-工作单元和仓储设计】
- JavaScript - 代码片段,Snippets,Gist
- Python爬虫:requests模块的基本使用
- JS bind()方法、JS原生实现bind()
- Java面向对象编程 -4
- A10131013 Battle Over Cities (25分)
- LeetCode简单题(四)
- 【Fine学习笔记】Jmeter笔记
- spring使用context:property-placeholder载不进属性问题
- github 初体验