方法1
#include <stdio.h>
#include <string.h>#define N 4//单词的个数
#define M 20//单词的长度
int main(void)
{
char str[N][M],str1[M];
int i;
for(i=0;i<N;i++)
{
gets(str[i]);
}
for(i=0;i<N/2;i++)
{
strcpy(str1,str[i]);
strcpy(str[i],str[N-1-i]);
strcpy(str[N-1-i],str1);
}
for(i=0;i<N;i++)
{
puts(str[i]);
}
return 0;
//这种方法。我写的好理解。但是没有实际用途
方法2
## include <stdio.h>
# include <string.h>
void fun(char* a,char* b)
{// i am a student
int i,j,k=0;
for(i=strlen(a)-1;i>=0;i--)//首先将冲击字符串的长度。长度减一。长度不包含结束符。
{
if(a[i]==' ')
{
for(j=i+1;a[j]!='\0'&&a[j]!=' ';j++)//j是从单词开始的。而不是空格(j=i+1)
{
b[k++] = a[j];//将单词保存在b数组里
}
b[k++] = ' ';//要值数组的下一个字符为空格。因为要与数组a的空格相对应。
}
}
for(i=0;a[i]!=' ';i++)
b[k++] = a[i];
b[k] = '\0';
}
int main(void)
{
char a[20],b[20];
printf("请输入字符串");
gets(a);
printf("字符串逆序后为:");
fun(a,b);
printf("%s",b);
printf("\n");
return 0;
}
本题的思路分析:巧妙之处在于。我们是从后面的字符开始遍历