1.实现一个函数,可以左旋字符串中的k个字符。
ABCD左旋一个字符得到BCDA
ABCD左旋两个字符得到CDAB
这个题目我们初次看着,会发现它很简单,其实不然,我在写的时候发现了好多的问题。首先我们要明确的是,我们要输入的是字符串。
我们知道,要输入一个字符串我们可以采用将其存入数组的方法,也就是scanf("%s",array),在这里我们要注意得是,我们用的是%s而并非%c,这样我们就可以将一整串字符串输入进我们的数组当中。
下面就进入到我们的重点部分,如何将字符串进行左旋呢?我们可以这样想,所谓的字符串左旋,就是将第一位放在最后一位的位置上,而其余的各个字符依次向前移动一位,这样就可以得到我们想要的字符串翻转后的值了。
具体代码如下
```c
#include<stdio.h>
#include<string.h>
#include<windows.h>
#pragma warning(disable:4996)
int main()
{
int i=0;
int m;
int num;
char a[100];//定义一个数组,用来存放我们将要输入的字符串
printf("请输入一个字符串:\n");
scanf("%s",a);//将字符串存入我们已经定义好的数组中
printf("请输入你要左旋的次数:");//输入我们要左旋的次数
scanf("%d", &m);
num = strlen(a);//求字符串的长度
while (m)///确定我们要左旋的次数
{
char temp = a[0];//用一个中间值
for (i= 0; i < num-1; i++)
{
a[i] = a[i + 1];//将每一位往前移一位
}
a[i] = temp;//将第一个值给最后一位
m--;
}
printf("%s", a);
system("pause");
return 0;
}
本人在进行编码的时候遇到了一些我们常见的问题,希望大家在写这个代码的时候细心一点。