小技巧----“三步翻转法”
来源:程序员人生 发布时间:2016-06-07 08:16:47 阅读次数:3586次
例:实现字符串左移函数,比如"abcdefghi"循环左移3位就是”defghiabc".
#include<stdio.h>
#include<stdlib.h>
#include<assert.h>
#include<string.h>
void revers(char *left,char *right) //翻转函数,left代表起始位置,right代表结束位置
{
assert(left);
assert(right);
char tmp = 0;
while (left < right)
{
tmp = *left;
*left = *right;
*right = tmp;
left++;
right--;
}
}
void leftLoopMove(char *pStr, unsigned short steps)
{
assert(pStr);
int len = strlen(pStr);
steps = steps%len; //这样可以处理steps不合法的情况
revers(pStr,pStr+steps⑴); //首先翻转前steps个字符
revers(pStr + steps, pStr + len - 1); //再翻转剩下的字符
revers(pStr, pStr + len - 1); //再将整体翻转
}
int main()
{
char arr[50] = { 0 };
unsigned short steps = 0; //要右移的个数
scanf("%s%hd",arr,&steps);
leftLoopMove(arr,steps);
printf("%s\n", arr);
system("pause");
return 0;
}
生活不易,码农辛苦
如果您觉得本网站对您的学习有所帮助,可以手机扫描二维码进行捐赠