给定一句英语,要求你编写程序,将句中所有单词的顺序颠倒输出。
输入格式:
测试输入包含一个测试用例,在一行内给出总长度不超过 80 的字符串。字符串由若干单词和若干空格组成,其中单词是由英文字母(大小写有区分)组成的字符串,单词之间用 1 个空格分开,输入保证句子末尾没有多余的空格。
输出格式:
每个测试用例的输出占一行,输出倒序后的句子。
输入样例:
Hello World Here I Come
输出样例:
Come I Here World Hello
AC了我自己都觉得很意外。因为我一直用VC6.0调试的,这个程序在VC貌似是个死循环,但用gcc编译竟然奇迹通过了???
基本思路:建立一个二维数组,以空格为标志,把输入的每个单词(可以看成是字符串)按顺序保存在二维数组的每行,最后以行为单位倒着输出二维数组里的字符串,完成。
虽然代码看起来很简短,事实上想了挺久的(大概是比较笨的原因) ̄□ ̄||,当然我不确定有没有撞运气的成分在。
#include <stdio.h>
int main()
{
char a[101][80],c;
int i=0,k=0;
while((c=getchar())!='\n')
{
if(c==' ')
{
i++;
k=0;
}
else
a[i][k++]=c;
}
for(int j=i;j>0;j--)
printf("%s ",a[j]);
printf("%s\n",a[0]);
}
/*AC了我自己都觉得很意外。因为我一直用VC6.0调试的,这个程序在VC貌似是个死循环,但用gcc编译竟然奇迹通过了???*/
/*基本思路:建立一个二维数组,以空格为标志,把输入的每个单词(可以看成是字符串)按顺序保存在二维数组的每行,最后以行为单位倒着输出二维数组里的字符串,完成。*/
/*虽然代码看起来很简短,事实上想了挺久的(大概是比较笨的原因) ̄□ ̄||*/