目录
整体思路
这个题目的意思是什么呢?我举个例子:有这样的一句话,”i like beijing.”,我们想要得到的结果是”beijing. like i”。那么我们应该用什么方法来实现呢?我们应该有个大体的思路:我们可以先将整个句子逆序得到”.gnijieb ekil i”,然后再将每个单词逆序得到”beijing. like i”。这样我们是不是就达到想要的结果了呢。那么知道了怎么做,我们就需要用代码来实现。
代码实现
#include<stdio.h>
#include<string.h>
int main()
{
char arr[101] = {0};
gets(arr) //兄弟们记住,这里最好不要用scanf,因为scanf读取到空格就会停止
int len = strlen(arr); //后面我们需要用到字符串的长度
//逆序整句话
ReverseStr(arr,arr+len-1); //用函数来实现这个功能,后面还会再用到
}
这里关键就是ReverseStr函数的实现,这个函数既可以用来逆序整句话,也可以用来逆序单独的单词,我们只需要控制传进的参数就可以了。
ReverseStr函数的实现
void ReverseStr(char *left,char *right)
{
while(left<right)
{
char tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
在逆序完整句话之后,我们就来实现对单独单词的逆序
char* cur = arr;
while(*cur)
{
char *start = cur; //将每个单词的首字母的字符给start
while(*cur != ' ' && *cur != '\0') //这里不等于'\0'防止数组越界
{
cur++;
}
ReverseStr(start,cur-1)
if(*cur != '\0') //防止当cur指向'\0'时跳过‘\0’指向下一个位置,从而导致程序无法停止
cur++;
}
这些完成了就基本实现了这个功能,下面就是代码的整体实现
代码的整体实现
#include<stdio.h>
#include<string.h>
void ReverseStr(char* left, char* right)
{
while (left < right)
{
char tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
int main()
{
char arr[101] = { 0 };
gets(arr);
int len = strlen(arr);
//逆序整句话
ReverseStr(arr, arr + len - 1);
//单词逆序打印
char* cur = arr;
while (*cur)
{
char* start = cur;
while (*cur != '\0' && *cur != ' ')
{
cur++;
}
ReverseStr(start, cur-1);
if (*cur != '\0')
cur++;
}
printf("%s", arr);
return 0;
}
今天就分享到这里了,祝大家在以后写代码的路上越写越顺。
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。
文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/192676.html