题目:
将一句话的单词进行倒置,标点不倒置。比如 “I like beijing.”,经过处理后变为:“beijing. like I”。字符串长度不超过100。
这里我们可以将字符串分成两部分进行看。第一部分我们将每个单词当成一个字符串。第二部分我们将 I like beijing. 看成一个字符串。
那么我们的思路就有了第一步先将每个单词进行倒置结果为 I ekil .gnijieb ,第二步再将整个字符串进行倒置 结果为 beijing. like I
按着这个思路代码如下:
#include<stdio.h>
#include<assert.h>
#include<string.h>
void my_jx(char* start, char* end)//该函数将字符串进行倒置
{
assert(start);//进行断言,保证指针有效性
assert(end);
while (start < end)
{
char tmp = *end;
*end = *start;
*start = tmp;
start++;
end--;
}
}
int main()
{
char arr[101]={0};
gets(arr);
char* err = arr;
while(*err)//将字符串里的每个单词进行逆序
{
char* start = err;
char* end = err;
while(*end!=' '&&*end!='\0')
{
end++;
}
my_jx(start, end - 1);
err = end + 1;
}
int sz=strlen(arr);
my_jx(arr, arr + sz - 1);//这里将前面每个单词逆序好的再次逆序(这次是整体逆序)
printf("%s", arr);
return 0;
}
效果如下: