注册 登录
编程论坛 C++教室

5. 神奇的清除栈

ljp294777643 发布于 2020-11-01 18:14, 3551 次点击
【问题描述】
学完栈的知识后,小童和小美一起做了一个有趣的游戏,游戏规定:向栈里面输入n个大写字母
(用空格隔开),如果输入的字母是C,就需要把前面的字母都删除,最后把剩下的字符按照输入顺
序倒序输出,若栈为空,就输出大写字母C。
【输入格式】
 两行,第一行包含一个数字n(0<n<100),第二行包含n个大写字母。
【输出格式】
 若栈为空,输出大写字母C,若不为空,将字母按输入顺序倒序输出。
【输入样例】
10
A A A B B C D E F R
【输出样例】
R F E D
(看题目,c++解)
4 回复
#2
rjsp2020-11-01 21:04
看不懂
如果没出现C,输入 A B D,那应该输出什么?
如果出现多个C,输入 A B C D E C F G,那应该输出什么?
#3
rjsp2020-11-01 21:32
程序代码:
#include <iostream>
using namespace std;

struct mystack
{
    char buf[100];
    unsigned size = 0;
};

bool push( mystack& s, char value )
{
    if( value == 'C' )
    {
        s.size = 0;
        return true;
    }

    if( s.size == sizeof(s.buf)/sizeof(*s.buf) )
        return false;

    s.buf[s.size++] = value;
    return true;
}

bool pop( mystack& s, char& value )
{
    if( s.size == 0 )
        return false;

    value = s.buf[--s.size];
    return true;
}

int main( void )
{
    unsigned n;
    cin >> n;

    mystack s;
    for( unsigned i=0; i!=n; ++i )
    {
        char value;
        cin >> value;

        push( s, value );
    }

    int main( void )
{
    unsigned n;
    cin >> n;

    mystack s = {};
    for( unsigned i=0; i!=n; ++i )
    {
        char value;
        cin >> value;

        push( s, value );
    }

    if( s.size == 0 )
        cout << "C ";
    else
        for( char value; pop(s,value); )
        {
            cout << value << ' ';
        }
}
}


[此贴子已经被作者于2020-11-2 12:49编辑过]

#4
lin51616782020-11-02 11:28
回复 3楼 rjsp
你好像没有处理 栈空 单独输出C的情况
#5
rjsp2020-11-02 12:46
回复 4楼 lin5161678
谢谢,确实少了
1