上一章节反转字符串https://blog.csdn.net/weixin_44681167/article/details/120235252?spm=1001.2014.3001.5501
由于上一章节,我已经讲过普通的反转方法(暴力反转法),这一章节我们讲一个简单的反转方法,只需要三步
第一步:获得我们的数组
第二步:分别旋转,我们这里设置k为2,则左边旋转k个,也就是两个,后面全部旋转
第三步:全部旋转
代码实现如下
void change(char* a, int k)
{
int len = strlen(a);
reverse(a, a + k - 1 );//旋转左边
reverse(a+k, a + len - 1);//旋转右边
reverse(a, a + len - 1);//旋转整体
}
接下来,这是如何旋转的代码,首先我们先获取到我们要旋转的左边的下标和右边的下标,然后交换位置
void reverse(char* left,char* right)
{
while (left<right)
{
char t = *left;
*left = *right;
*right = t;
left++;
right--;
}
}
最后我们的代码就写好了,只需要在main函数里面调用即可
int main()
{
char a[] = "abcdef";
change(a, 2);
printf("%s\n", a);//输出整个字符串
return 0;
}
最后我们来运行一下吧
完美!