主要思路即:对于第一个和最后一个单词,由于比较特殊,前后共有一个空格,所以单独输出;中间的单词有两个空格,可以循环输出。用一个整形数组来存储输入句子中空格的位置来加以辅助
#include<stdio.h>
#include<string.h>
int main()
{
int i,j=0,k;
char a[81];//防止输入刚好80个单词
gets(a);
int b[81];
int l=strlen(a);
for(i=0;i<l;i++)
{
if(a[i]==' ')
{
b[j++]=i;
}
}
if(j==0)//需要考虑到只有一个单词的情况
{
printf("%s\n",a);
}
else
{
k=b[j-1]+1;//最后一个空格
while(a[k]!='\0'&&k<80)//输出最后一个单词
{
printf("%c",a[k]);
k++;
}
for(i=j-2;i>-1;i--)//j-2-(j-1)从数组b的j-2位置开始,向前要走j-1次,输出中间的单词
{
for(k=b[i];k<b[i+1];k++)
{
printf("%c",a[k]);
}
}
printf(" ");
for(i=0;i<b[0];i++)//输出第一个单词
{
printf("%c",a[i]);
}
printf("\n");
}
return 0;
}
比较容易出现的问题,一是考虑不全,没有想到只有一个单词的情况;而是数组大小没定义对,容易出现越界的情况