实现字符串右循环移位

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了实现字符串右循环移位相关的知识,希望对你有一定的参考价值。

实现字符串右循环移位函数,例如“abcdef”循环右移2位就是“cdefab”。

#include <stdio.h>
#include <stdlib.h>
void left_move(char arr[], int k)
{
	int i = 0;
	int len = strlen(arr);
	for (i = 0; i<k; i++)
	{
		char tmp = arr[0];
		int j = 0;
		for (j = 0; j<len - 1; j++)
		{
			arr[j] = arr[j + 1];
		}
		arr[len - 1] = tmp;
	}
}
int main()
{
	char arr[] = "abcdef";
	int k = 0;
	scanf("%d", &k);
	left_move(arr, k);
	printf("%s\n", arr);
	system("pause");
	return 0;
}

//法2:三步翻转法
#include <stdio.h>

void reverse(char *left, char *right)
{
	while (left < right)
	{
		char tmp = *left;
		*left = *right;
		*right = tmp;
		left++;
		right--;
	}
}
void left_move(char arr[], int k)
{
	int len = strlen(arr);
	reverse(arr + 0, arr + k - 1);
	reverse(arr + k, arr + len - 1);
	reverse(arr + 0, arr + len - 1);
}

int main()
{
	char arr[] = "abcdef";
	int k = 0;
	scanf("%d", &k);
	left_move(arr, k);
	printf("%s\n", arr);
	system("pause");
	return 0;
}


以上是关于实现字符串右循环移位的主要内容,如果未能解决你的问题,请参考以下文章

矩阵循环移位

巧妙使用两次反转,轻松解决循环移位问题

C语言 循环移位

编程之美 2.17-字符串循环移位

C++ - 如何左/右循环移位一个位集?

循环移位算法