给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
思路:先用一维数组储存句子,再存入二维数组,其中每个一维数组都储存一个单词,最后逆序输出。
代码:
#include<stdio.h>
int main()
{
int i=0,j,t;
char a[100][20]={'\0'},str[100]={'\0'};//记得赋初值
gets(str);
for(t=0;str[t]!='\0';t++)
{
for(j=0;str[t]!=' '&&str[t]!='\0';t++,j++) a[i][j]=str[t];//str数组如果碰到空格和结尾a数组行数i就加一,否则str和a数组列数均加一
a[i][j]='\0';//给a数组每行加个尾巴
i++;
}
for(i--;i>=0;i--)//倒序输出
{
if(i!=0) printf("%s ",a[i]);
else printf("%s",a[i]);
}
return 0;
}
总结:。。。。。。原本想输入时一个单词一个单词的输入,但不知道单词个数处理很麻烦。。。