//设计思想:先对每个单词进行逆序,而后对整个字符串进行逆序
#include <stdio.h>
/*
*函数:inverse()
*描述:实现逆序的功能,参数为原串,返回值为空
*/
void inverse(char *src)
{
char *start = src;//作为指向每个单词的起始指针
char *end = src;//作为指向每个单词结尾的指针
char *p = src;//中间指针
char temp;//定义中间变量用于交换字母
if(src == NULL)
{
printf("error!\n");
}
while(*p++ != '\0')
{
if(*p == ' ' || *p == '\0')//表明*(p-1)指向单词尾部
{
end = p-1;
while(start < end)
{
temp = *start;
*start = *end;
*end = temp;
end--;
start++;
}
start = p +1;//指向下一个单词的开始
}
}
//以上完成了对每个单词内部的逆序,指针p-1指向尾字符下面将整个字串逆序
start = src;
end = p-2;
while(start < end)
{
temp = *start;
*start = *end;
*end = temp;
start++;
end--;
}
}
/*
*函数:main()
*描述:
*/
int main()
{
char src[50] = "I am a student.";
inverse(src);
printf("%s\n",src);
return 0;
}
最后可以输出student. a am I.