思路 :先将整个数组逆序,再将数组中的每个单词逆序,就可以达到字符串以单词为单位进行逆序。
举例:
1、输入:I like China
2、将整个数组逆序:anihC ekil I
3‘’将字符串中的每个单词逆序: China like I
代码如下:
#include<stdio.h>
#include<string.h>
//char* left 字符串第一个字符的地址
//char* right 字符串最后一个字符的地址
void reverse(char* left, char* right)
{
char ch = 0;//用来暂存一个字符
while (left < right)
{
ch = *left;
*left = *right;
*right = ch;
left++;
right--;
}
}
int main()
{
char arr[100] = { 0 };//声明并初始化一个数组
//提示
printf("请输入字符串:>\n");
//输入字符串
gets_s(arr);//之所以不用scanf是因为scanf不能读取空格,而gets_s可以读取空格
int len = strlen(arr);//求字符串长度
//将整个字符串逆序
reverse(arr, arr + len - 1);
//对字符串每个单词进行逆序
char* start = arr;//声明一个字符指针变量start,初始化赋地址为arr,用来指向单词第一个字母
while (*start)//因为‘\0’的ASCLL值为0,且0为假,所以指针*start指向的内容为‘\0’,循环结束。
{
char* end = start;//声明一个字符指针变量end,初始化赋地址为start,后面用来表示单词最后一个字母后面的一块地址: 空格 或‘\0’
while (*end != ' ' && *end != '\0')//指针*end指向的内容为 空格 或 ‘\0’则结束循环
{
end++;//地址end加一,使指针指向的内容不断接近 空格 或 ‘\0’
}
reverse(start,end-1);//此时地址end里的内容为 空格 或 ‘\0’,所以 ch-1 为 空格 或 ‘\0’前面的一块地址,也就是单词最后一个字母的地址
if (*end == ' ')//指针*end指向的内容为 空格 说明后面还有单词
{
start = end + 1;//此时end为 空格 的地址,加1就等于下一个单词的第一个字母
}
else//否则*end==‘\0’说明后面没有单词,将end赋给start。则指针*start指向的的内容为‘\0’,循环结束
{
start = end;
}
}
//输出字符串
printf("%s\n",arr);
return 0;
}