题解 | #堆栈的使用#

堆栈的使用

https://www.nowcoder.com/practice/e91982a145944ceab6bb9a4a508e0e26


//这个算法只能用于整数是一位数的情况,而题目里说  0 < n <= 10000

/*转到第19行
        string temp;///!!!!!!!!
        getline(cin,temp);//唉,这个错误折磨了我很久才发现。就是第一行数字后面有个换行符要接收一下才能正常地接收后续每一行地字符串,不然就默认接受的第一个字符串时数字后面的换行符

#include <iostream>
#include <stack>
using namespace std;

int main() {
    int n;
    while (cin >> n) {
    stack<char> num;
    while(!num.empty())num.pop();//C++没有提供可以调用的栈清空函数,要手动清空


        string temp;///!!!!!!!!
        getline(cin,temp);//唉,这个错误折磨了我很久才发现。就是第一行数字后面有个换行符要接收一下才能正常地接收后续每一行地字符串,不然就默认接受的第一个字符串时数字后面的换行符


        for(int i=1;i<=n;i++)
        {
            string str;
            getline(cin,str);//必须接受一行不能用cin>>str;
                if(str[0]=='A')
                {
                    if(num.empty())
                    {
                        cout<<"E"<<endl;
                    }
                    else
                    {
                        cout<<num.top()<<endl;
                    }

                }
                else if(str[0]=='P')
                {
                    num.push(str[2]);

                }
                else {
                    if(num.empty())continue;
                    else num.pop();
                }
        }

    }
}
*/


#include <iostream>
#include <stack>
using namespace std;

int main()
{
    int n;
    while (cin >> n)
    {
        stack<int> num;
        for(int i=1;i<=n;i++)
        {
            char x;
            int y;
            cin>>x;
            if(x=='A')
            {
                    if(num.empty())
                    {
                        cout<<"E"<<endl;
                    }
                    else
                    {
                        cout<<num.top()<<endl;
                    }
            }
            else if(x=='P')
                {
                    cin>>y;
                    num.push(y);

                }
            else
            {
                    if(num.empty())continue;
                    else num.pop();
            }
        }
    }
}







全部评论

相关推荐

一个非常好用的遍历方法
AomaYple:不是指针,是引用
点赞 评论 收藏
分享
评论
点赞
收藏
分享
正在热议
# 25届秋招总结 #
442727次浏览 4513人参与
# 春招别灰心,我们一人来一句鼓励 #
42019次浏览 533人参与
# 北方华创开奖 #
107439次浏览 599人参与
# 地方国企笔面经互助 #
7964次浏览 18人参与
# 同bg的你秋招战况如何? #
76743次浏览 563人参与
# 实习必须要去大厂吗? #
55775次浏览 961人参与
# 阿里云管培生offer #
120292次浏览 2220人参与
# 虾皮求职进展汇总 #
115687次浏览 886人参与
# 如果你有一天可以担任公司的CEO,你会做哪三件事? #
11584次浏览 287人参与
# 实习,投递多份简历没人回复怎么办 #
2454714次浏览 34857人参与
# 提前批简历挂麻了怎么办 #
149906次浏览 1977人参与
# 在找工作求抱抱 #
906039次浏览 9421人参与
# 如果公司给你放一天假,你会怎么度过? #
4757次浏览 55人参与
# 你投递的公司有几家约面了? #
33207次浏览 188人参与
# 投递实习岗位前的准备 #
1195967次浏览 18550人参与
# 机械人春招想让哪家公司来捞你? #
157635次浏览 2267人参与
# 双非本科求职如何逆袭 #
662248次浏览 7397人参与
# 发工资后,你做的第一件事是什么 #
12734次浏览 62人参与
# 工作中,努力重要还是选择重要? #
35815次浏览 384人参与
# 简历中的项目经历要怎么写? #
86924次浏览 1516人参与
# 参加完秋招的机械人,还参加春招吗? #
20133次浏览 240人参与
# 我的上岸简历长这样 #
452024次浏览 8088人参与
牛客网
牛客企业服务