PAT 乙级1009 说反话

给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。

输入格式:

测试输入包含一个测试用例,在一行内给出总长度不超过80的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用1个空格分开,输入保证句子末尾没有多余的空格。

输出格式:

每个测试用例的输出占一行,输出倒序后的句子。

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello 

/***************************************************/

分析:

error:1.对stack的理解不够深入,以为stack的每一场空间只能放一个元素,比如一个数字或者一个字母,实际上是可以放一个变量,比如a=“1234”,s=“asdasd”。

           2.getline()函数是读取一行字符串,当遇到如下三种情况会结束读操作:1)到文件结束,2)遇到函数的定界符,默认为换行符 3)输入达到最大限度。

 我之前将if(i==str.length()-1)写为if(str[i]=='\n'),但是发现stack中始终么有str中最后一串。比如str=“asd   df  as”,stack中只有asd和df。后来发现是对getline()函数理解不到位,它遇到换行符就停止读操作,并且不会将换行符读入str中。

/**************************************************/

#include <iostream>
#include <stack>
using namespace std;
int main() {
    int sign=0;     //控制输出的标志 
    stack<string> v; //定义一个存放string类型数据的stack' 
    string str;
    getline(cin,str);   //读取字符串 
    string arr="";
    for(int i=0;i<str.length();i++)    //将字符串以‘’为界限分开存入stack 
    {
        if(i==str.length()-1)
        {
            arr+=str[i];
            v.push(arr);
            break;
        }
        if(str[i]!=' ') arr+=str[i];
        else{
            v.push(arr);
            arr="";
        }
    }
    while(!v.empty()) {      //输出 
        if(sign==1) cout<<" ";
        cout<< v.top();
        v.pop();
        sign=1;
    }
    return 0;
}

PAT乙级1009题是一个关于字符串处理的题目。根据题目要求,我们需要将输入字符串按照单词的逆序输出。根据提供的引用内容,我们可以看到有三种不同的解法。 引用\[1\]和引用\[2\]是两个相似的解法,使用了字符串处理函数strchr和strrchr来定位空格字符,并将字符串分割成单词。然后通过循环输出单词,最后输出剩余的最后一个单词。 引用\[3\]是另一种解法,使用了二维数组来存储每个单词。通过循环读取输入字符串,直到遇到换行符为止。然后通过倒序循环输出每个单词。 根据题目要求,你可以选择其中一种解法来完成PAT乙级1009题。 #### 引用[.reference_title] - *1* [PAT考试乙级1009(C语言实现)](https://blog.csdn.net/JeffreyDDD/article/details/78395267)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* [PAT乙级1009(C语言实现)](https://blog.csdn.net/weixin_62870950/article/details/124934829)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *3* [PAT乙级测试1009(C语言实现)](https://blog.csdn.net/weixin_45947840/article/details/105943475)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值