思路:首先将整个字符串倒序输出(esenihC dna anihC evol I),然后将每一个单词分别倒序输出(Chinese and China love I)
#include <stdio.h>
#include <string.h>
int main(int argc, char const *argv[])
{
char a[32] = "I love China and Chinese";
char *p = a, *q = p + strlen(a) - 1, *k = NULL;
char t;
while (p < q)//首先全部反转
{
t = *p;*p = *q;*q = t;
p++;q--;
}
puts(a);
p = q = a;
while(*p!='\0')
{
while(*p==' ')
{
k=p++;//保存空格的地址,然后p向高地址移动一位,即p指向下一个单词的首字母
while(q<k)
{
t=*q;*q=*(k-1);*(k-1)=t;//反转q和k之间的字母
q++;k--;
}
q=p;//同步q与p的位置,即q指向下一个单词的首字母,以便对下一个单词进行反转
}
p++;
}
puts(a);
return 0;
}