您的位置:首页 > 其它

一段完美实现字符串倒序的算法!

2016-11-26 10:53 225 查看
程序功能 : 输入 i am happy

输出 happy am i

特点:自己想了一个实现字符串倒序的算法,可实现一个字符串中的某一段代码倒序,其它不变
#include<stdio.h>
#include<string.h>
#define MAX_SIZE 100//作用输入 i am happy => happy am i

void daoxu(char *str,int p,int len)//p是交换的起始位置,len是要交换的长度。
{
int i;
char temp;
for(i = 0;i < len / 2;i++)
{
temp = *(str + i + p);
*(str + i + p) = *(str +len + p - 1 - i);
*(str + len + p - 1 - i) = temp;

}
}

void zhengxu(char *str)
{
int i;
int len = 0;
int temp = 0;
for(i = 0;*(str + i) != '\0';i++)
{
if(*(str + i) == ' ')
{
len = i - temp;
daoxu(str,temp,len);
temp = i + 1;
}
}
len = i - temp;
daoxu(str,temp,len);
}

int main()
{
char str[MAX_SIZE];

printf("please input string :\n");
gets(str);
daoxu(str,0,strlen(str));//将所有字母倒序
zhengxu(str);//将每个单词倒序

printf("%s\n",str);
return 0;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  算法 字符串倒序