当前位置: 代码迷 >> 综合 >> PTA--1009 说反话(C语言)
  详细解决方案

PTA--1009 说反话(C语言)

热度:42   发布时间:2023-12-06 10:15:31.0

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

输入格式:

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

输出格式:

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

样例:">样例:">输入样例:

Hello World Here I Come

输出样例:

Come I Here World Hello

 解析:利用数组,利用其中的空格来倒序输出

#include <stdio.h>
#include <string.h>
char k[90];
int main()
{int a=0,b=0,l=0,s=0,i=0,cnt=0,kong=0;while(gets(k)!=NULL){   //多个输入l=strlen(k);b=l-1;for(i=0;i<l;i++){if(k[i]==' ') kong++;//判断单词是否为多个}if(kong!=0){    //分一个单词和多个单词来不同处理 for(i=l-1;i>=0;i--){if(k[i]==' '){a=i+1;    //a表示单个单词的起始位置 if(cnt==1) printf(" ");cnt=1;for(s=a;s<=b;s++){printf("%c",k[s]);}b=i-1;    //b表示单个单词的末尾 }}if(cnt==1) printf(" ");for(i=0;;i++){if(k[i]==' '){break;}printf("%c",k[i]);}printf("\n");cnt=0;}else if(kong==0){printf("%s\n",k);}}return 0;
}