1009 说反话 (20 分)
给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
#include<stdio.h>
#include<string.h>
#include<stdlib.h>
int main()
{
int i=0,j;
char c;
char str[100][100];
int dan=80; //每一组单词 ,虽然是正序输入,但是这里控制了下标,所以单词会自动从末尾往前排
while((c=getchar())!='\n')
{
if(c==' ')
{
str[dan][i]='\0';
dan--;
i=0;
continue;
}
else
{
str[dan][i]=c;
i++;
}
}
str[dan][i]='\0'; //换行后就跳出了循环,所以要记得给最后一个单词补结束符
for(i=dan;i<80;i++) //别看这里是正序循环,是因为输入时倒序输入
printf("%s ",str[i]);
printf("%s",str[i]); //最后输入的一个单词没有空格
}