代码:
#include<stdio.h>
#define N 10
int main()
{
/*输入字符串,str[10],将里面的字符逆反排列,再输出。*/
char ch[N];
int num = 0,i,j,temp;
gets(ch);//gets函数会自动在最后补一个\0
for(i = 0; i < N; i++)
{
if(ch[i] != '\0')
{
num++;
}
}
for(i = 0; i < num/2; i++)
{
temp = ch[i];
ch[i] = ch[num - i - 1];
ch[num - i - 1] = temp;
}
for(j = 0; j < num; j++)
{
printf("%c",ch[j]);
}
return 0;
}
需要注意的是,gets函数的特性是在你向数组输入完字符后,自动在最后一个字符的后面一个数组空间赋上一个\0,其实说白了就是让你这一串字符变成字符串。
同时我们可以利用这个特性,逐个检索字符数组,就可以计算数组的中有多少个字符,遇到\0的时候就停止计算。
下一步就是对数组内的字符进行交换,头和尾进行交换,最后就实现了对整个数组的逆转,最后进行输出。
需要注意的是,当我们在进行对调的时候,对调的次数是字符数量的一般,num/2 就是这么来的,我们计算字符数组的数量的原因就是要用在对调字符位置。