问题:

     3.实现一个函数,可以左旋字符串中的k个字符。

        AABCD左旋一个字符得到ABCDA

        AABCD左旋两个字符得到BCDAA

#include<stdio.h>
#include<assert.h>
#include<string.h>
void reserve(char* str, int len)
{
	assert(str);
	char* start = str;
	char* end = str + len - 1;
	while (start < end)
	{
		char tmp = *start;
		*start = *end;
		*end = tmp;
		start++;
		end--;
	}
}
void reserve1(char* str, int len, int k)
{
	reserve(str, len);//dcbaa
	assert(str);
	char* start = str ;
	
	if (k < len)
	{
		char* end = str + len - 1 - k;
		while (start < end)
		{
			char tmp = *start;
			*start = *end;
			*end = tmp;
			start++;
			end--;
		}
	}
	else
	{
		printf("输入的字符串个数太大\n");
	}
}
void reserve2(char* str, int len,int s)
{
	assert(str);
	reserve1(str, len, s);//cdbaa
	char* start = str+len-s;
	char* end = str + len - 1;
	while (start < end)
	{
		char tmp = *start;
		*start = *end;
		*end = tmp;
		start++;
		end--;
	}
}
int main(void)
{
	char str[] = "aabcd";
	int len = strlen(str);
	int s;
	printf("请输入要旋转的字符串个数\n");
	scanf_s("%d", &s);
	reserve2(str, len, s);
	printf("%s", str);
}