题目描述:

用两个栈来实现一个队列,完成队列的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

最新文章

  1. 菜鸟学Linux命令:lsof命令 查找指定用户、进程、端口打开的文件
  2. android 修改framework下资源文件后如何编译
  3. struts的hello world小试
  4. JAVA继承时this和super关键字
  5. Java [Leetcode 205]Isomorphic Strings
  6. 【高级JEE技术】JMX
  7. Android_HTML解析器_jsoup
  8. AndroidStudio项目移植到Eclipse
  9. 精讚部落::MySQL 的MEMORY engine
  10. itmacy_我的博客
  11. 深入浅出Hadoop之HDFS
  12. LVS实现负载均衡安装配置详解
  13. mybatis入门篇:代码生成器(MyBatis Generator)
  14. Linux chattr和lsattr命令使用方法
  15. 示例:pm_multiple_models 匹配——形状匹配
  16. vue.js安装问题
  17. 发送短信验证码倒计时,CountDownTimer;
  18. CentOS增加用户到sudo用户组
  19. HBase Rowkey的散列与预分区设计
  20. 快速上手最棒的网格框架ag-Grid

热门文章

  1. ASP.NET Core搭建多层网站架构【4-工作单元和仓储设计】
  2. JavaScript - 代码片段,Snippets,Gist
  3. Python爬虫:requests模块的基本使用
  4. JS bind()方法、JS原生实现bind()
  5. Java面向对象编程 -4
  6. A10131013 Battle Over Cities (25分)
  7. LeetCode简单题(四)
  8. 【Fine学习笔记】Jmeter笔记
  9. spring使用context:property-placeholder载不进属性问题
  10. github 初体验