给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
代码如下:
/*
将一个以空格符结束的单词看作一个整体
利用多点测试的输入方法更为简便的实现功能
*/
#include<cstdio>
#include<cstring>
const int maxn = 90;
int main(){
char str[maxn][maxn];
int num = 0;
while(scanf("%s",str[num])!=EOF){
num++;
}
for(int i=num-1;i>=0;i--){
printf("%s",str[i]);
if(i>0)
printf(" ");
}
return 0;
}
注:
str[a][b]表示该数组中有a个长度不超过b的字符串
输入数据后需换行ctrl+z 回车来表示数据输入完毕
单点测试代码:
#include<cstdio>
#include<cstring>
const int maxn = 90;
/*
利用多点测试的方式简便的实现
int main(){
char str[maxn][maxn];
int num = 0;
while(scanf("%s",str[num])!=EOF){
num++;
}
for(int i=num-1;i>=0;i--){
printf("%s",str[i]);
if(i>0)
printf(" ");
}
return 0;
}
*/
int main(){
char word[maxn];
fgets(word,maxn,stdin);
int len = strlen(word);
if(word[len-1]=='\n')//换行符改为空字符
word[len-1]='\0';
int a=0,b=0;
char str[maxn][maxn];
for(int i=0;i<len;i++){
if(word[i]!=' ')
str[a][b++]=word[i];
else{
str[a][b]='\0';
a++;
b=0;
}
}
for(int i=a;i>=0;i--){
printf("%s",str[i]);
if(i>0)printf(" ");
}
return 0;
}
注:因为OJ不支持gets函数所以采用fgets函数代替,需要注意的是fgets函数默认输入的数据末尾以换行符结束,所以需要改为空字符,即
if(word[len-1]=='\n')
word[len-1]='\0';