要逆置这个字符串,有很多种方法,在此说一次比较巧妙的方法
首先,逆置这个字符串,可以考虑单独的把每个单词都逆序一下,在对整个字符串进行逆序
考虑本题中的I like beijing.
首先对I、like、beijing. 中的每个单词逆序,由此变成I、ekil、.gnijie变成这样之后,在对整个字符串进行逆序就行了
代码展示如下
void reverse_string(char* left, char* right) {
while (left < right) {
char temp = *left;//这里可以用地址的方式进行逆序
//整个函数被传递过来的时候是整个栈帧都传递过来了
*left = *right;
*right = temp;
left++;
right--;
}
}
int main() {
char arr[101] = { 0 };
gets_s(arr);
char* cur = arr;
while (*cur) {
char* start = cur;
char* end = cur;
while (*end != ' ' && *end != '\0') {
end++;
}
reverse_string(start, end - 1);
if (*end == ' ')
cur = end + 1;
if (*end == '\0')
cur = end;
}
printf("%s\n", arr);
int len = strlen(arr);
reverse_string(arr, arr + len - 1);
printf("%s\n", arr);
return 0;
}