PAT1009 说反话 (20 分) c++ 解法:
题目:1009 说反话 (20 分)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
思路:
由于题目要求完成句子的倒序,那么可以考虑将空格当成分隔符,那么每一个单词就成为了一个单独的字符串,就可以使用string库的substr(pos,len)方法。
注意:这里的cin不能直接用于输入完整的字符串(因为cin遇到空格或者回车就会停止输入),所以先使用cin.get(s, len)进行输入,这里的s是char类型的数组,len为要输入的字符数量,遇到空格不会停止输入,只有遇到回车才会停止。
之后使用string str(s);进行字符数组到字符串的转化就可以啦~
具体代码如下:
#include <cstdio>
#include <string>
#include <iostream>
using namespace std;
int main(){
char s[90];
cin.get(s,90);
string str(s);
int pos = str.size();
for(int i = str.length() - 1; i >= 0; i--){
if(str[i] == ' '){
cout << str.substr(i+1, pos - i - 1) << ' ';
pos = i;
}
if(i == 0){
cout << str.substr(0, pos);
}
}
return 0;
}