1009 说反话 (20 分)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
一开始完全不知道怎么切割字符串,网上看了一下参考了一种方法:从后往前遍历,遇到空格 利用cout<<c+n 输出c字符串n后的内容,同时为了避免输出过的再次输出,将空格变成cout的结束字符'\0'
//cin忽略空格
//cout 遇到 '\0'停止输出
//strlen直到遇到结束符'\0'。返回的长度大小不包括'\0'。 length()用来计算string
#include <stdio.h>
#include <iostream>
#include <cstring>
using namespace std;
int main(){
char c[82];
cin.getline(c+1,82);
//gets(c+1); //c表示这个char的首地址 +n表示从第n个开始输入 gets不支持不支持 换成换成getline
c[0] = ' ';
for(int i=strlen(c);i>=0;i--){
if(c[i] == ' '){
cout<<c+i+1;
c[i] = '\0';
if(i == 0){
cout<<'\0';
}
else{
cout<<" ";
}
}
}
return 0;
}
//cin忽略空格
//cout 遇到 '\0'停止输出
//strlen直到遇到结束符'\0'。返回的长度大小不包括'\0'。 length()用来计算string