九度_题目1512:用两个栈实现队列

这个思路实在太难想了。。。。

/*
 *str为PUSH,通过s1.push()使元素入栈;
 *str为POP时,s2非空,输出栈顶元素,s2.pop()弹出栈顶元素;若s2弹出元素后为空且s1不空,将s1中所有元素push进s2;
 *str为POP时,s2为空,若s1不空,将s1中所有元素push进s2,最后输出栈顶元素并通过<span style="font-family: Arial, Helvetica, sans-serif;">s2.pop()弹出栈顶元素</span>;
 */

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

#include<iostream>
#include<string>
#include<stack>
using namespace std;
/*
 *str为PUSH,s1.push();
 *str为POP时,s2非空,输出栈顶元素s2.pop();若s2弹出元素后为空,若s1不空,将s1中所有元素push进s2;
 *str为POP时,s2为空,若s1不空,将s1中所有元素push进s2,最后输出栈顶元素;
 */
int main()
{
    int n;
    while(cin>>n)
    {
            stack<int>s1,s2;
            int num;
            string str;
        for(int i=0;i<n;i++)
        {
            cin>>str;
            if(str=="PUSH")
        {
            cin>>num;
            s1.push(num);
        }else if(str=="POP")
        {
            if(!s2.empty())
            {
                cout<<s2.top()<<endl;
                s2.pop();
                if(s2.empty())
                {
                    if(!s1.empty())
                    {
                        while(!s1.empty())
                        {
                            s2.push(s1.top());
                            s1.pop();
                        }
                    }

                }
            }else
            {
                if(s1.empty())
                {cout<<-1<<endl;continue;}
                    else
                    {
                        while(!s1.empty())
                        {
                            s2.push(s1.top());
                            s1.pop();
                        }
                    }
                cout<<s2.top()<<endl;
                s2.pop();

            }
        }
        }
    }
}
/**************************************************************
    Problem: 1512
    User: hndxztf
    Language: C++
    Result: Accepted
    Time:580 ms
    Memory:1656 kb
****************************************************************/

时间: 2024-08-26 11:12:06

九度_题目1512:用两个栈实现队列的相关文章

九度_题目1352:和为S的两个数字

//用过map,超出内存的限制:用过静态数组,浪费空间不说,总是runtime error:还是用动态数组啊,左右夹逼,简洁明快 题目描述: 输入一个递增排序的数组和一个数字S,在数组中查找两个数,是的他们的和正好是S,如果有多对数字的和等于S,输出两个数的乘积最小的. 输入: 每个测试案例包括两行: 第一行包含一个整数n和k,n表示数组中的元素个数,k表示两数之和.其中1 <= n <= 10^6,k为int 第二行包含n个整数,每个数组均为int类型. 输出: 对应每个测试案例,输出两个数

九度_题目1356:孩子们的游戏(圆圈中最后剩下的数)

题目描述: 每年六一儿童节,JOBDU都会准备一些小礼物去看望孤儿院的小朋友,今年亦是如此.HF作为JOBDU的资深元老,自然也准备了一些小游戏.其中,有个游戏是这样的:首先,让小朋友们围成一个大圈.然后,他随机指定一个数m,让编号为1的小朋友开始报数.每次喊到m的那个小朋友要出列唱首歌,然后可以在礼品箱中任意的挑选礼物,并且不再回到圈中,从他的下一个小朋友开始,继续1...m报数....这样下去....直到剩下最后一个小朋友,可以不用表演,并且拿到JOBDU名贵的"名侦探柯南"典藏版

九度_题目1514:数值的整数次方

//0的正数次幂合法???哎呀,我去....数学学不好真可怕啊 题目描述: 给定一个double类型的浮点数base和int类型的整数exponent.求base的exponent次方. 输入: 输入可能包含多个测试样例. 对于每个输入文件,第一行输入一个整数T,表示测试案例的数目,接下来的T行每行输入一个浮点数base和一个整数exponent,两个数中间用一个空格隔开. 输出: 对应每个测试案例, 输出一个浮点数代表答案,保留两位小数即可. 样例输入: 5 1.0 10 0.0 -5 1.0

九度_题目1518:反转链表

//后插法建立链表,然后从第二个元素(若有的话)开始依次插入到头结点后面从而达到反转链表的效果 题目描述: 输入一个链表,反转链表后,输出链表的所有元素. (hint : 请务必使用链表) 输入: 输入可能包含多个测试样例,输入以EOF结束. 对于每个测试案例,输入的第一行为一个整数n(0<=n<=1000):代表将要输入的链表的个数. 输入的第二行包含n个整数t(0<=t<=1000000):代表链表元素. 输出: 对应每个测试案例, 以此输出链表反转后的元素,如没有元素则输出N

九度_题目1369:字符串的排列

//求一个字符串的全排列,我感觉自己实现真的是太难了.确定性的东西易求,但有点不确定的东西就难整了.标准模板库里面的算法算法next_permutation(arr,arr+strlen(arr))真的不错,尽管用cin cout会超时,但换成scanf printf就可以了 题目描述: 输入一个字符串,按字典序打印出该字符串中字符的所有排列.例如输入字符串abc,则打印出由字符a,b,c所能排列出来的所有字符串abc,acb,bac,bca,cab和cba. 输入: 每个测试案例包括1行. 输

九度_题目1349:数字在排序数组中出现的次数

//用map来实现总是超出最大的内存限制 题目描述: 统计一个数字在排序数组中出现的次数. 输入: 每个测试案例包括两行: 第一行有1个整数n,表示数组的大小.1<=n <= 10^6. 第二行有n个整数,表示数组元素,每个元素均为int. 第三行有1个整数m,表示接下来有m次查询.1<=m<=10^3. 下面有m行,每行有一个整数k,表示要查询的数. 输出: 对应每个测试案例,有m行输出,每行1整数,表示数组中该数字出现的次数. 样例输入: 8 1 2 3 3 3 3 4 5 1

剑指OFFER之用两个栈实现队列(九度OJ1512)

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

利用两个栈模拟队列

/************************************************** 题目:用两个栈模拟队列的基本操作1入队2,出队3判断队空4判断队满 s1做为输入栈的元素,一个个压栈相当于入队 s2作为输出队列的元素, 一个个出栈相当于出队 *************************************************/ #include <iostream> #include <cstdio> using namespace std; c

[剑指Offer]9.用两个栈实现队列

题目 用两个栈来实现一个队列,完成队列的Push和Pop操作. 队列中的元素为int类型. 思路 用栈来模拟队列.我们首先插入一个元素a到stack1中,再压入两个元素bc,此时栈中有元素abc,其中c位于栈顶,而stack2仍然为空.我们试着删除一个元素.按照队列先进先出的原则,我们应该先删除元素a.元素a存放在stack1中且不在栈顶,因此不能直接删除.注意到stack2还未使用,我们把stack1中的元素逐个弹出并压入stack2中,stack2中的元素是cba,栈顶元素是a,我们现在可以