PAT B1009 说反话

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

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

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

输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

代码如下:

/*
将一个以空格符结束的单词看作一个整体
利用多点测试的输入方法更为简便的实现功能
*/
#include
#include
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
#include
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=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';

你可能感兴趣的:(PAT)