若要完成这个题目,可以先逆序整个字符数组,逆序后为:i ma a tneduts;接下来对于每个单词进行逆序便可达到目的,结果为:i ma a student。
#include <stdio.h>
#include <string.h>
#include <assert.h>
void reverse_arr(char* left,char* right)
{
assert(left);
assert(right);
while (left<right)
{
char tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
char* reverse(char arr[])
{
int len = strlen(arr);
char *start = arr;
char *end = NULL;
char *ret = arr;
reverse_arr(arr,arr+len-1);//逆序整个字符串
while (*arr)
{
start = arr;
while ((*arr != ' ') && (*arr != '\0'))
{
arr++;
}
//找到空格
end = arr - 1;
reverse_arr(start,end);//逆序单个单词
if (*arr == ' ')
arr++;
}
return ret;
}
int main()
{
char arr[] = "student a am i";
//i ma a tneduts
//i ma a student
printf("%s\n", reverse(arr));
system("pause");
return 0;
}