1.功能简介
首先,以左旋转字符串为例解释一下要实现的功能。比如我们要对一个字符串数组char arr[]="abcdef"进行左旋转一个字符,操作之后的字符串就会变为"bcdefa"。同理左旋转两个字符之后就会变为"cdefab",右旋转也是类似的,就是把右边一定字符移到左边去。
2.编程思路
2.1:对数据进行初始化
char arr[] = "abcdef"; // 确定被操作的对象
int num = 0; // 初始化旋转个数
int l = 0; // 初始化字符串长度
printf("请输入旋转个数\n");
scanf("%d", &num);
l = strlen(arr);
2.2:实现具体移动的功能函数
void left_move(char* arr, int n, int m) // char arr[] 可互换 char* arr 因为都是首元素地址
{
assert(arr); // 只要传进来的是指针就断言一下,避免是空指针
int i = 0;
// 我们只操作字符串的前n个数,但是由于下边是0开始的,所以i < n
for (i = 0; i < n; i++)
{
// 1.先把第一个字符存在临时变量里
char temp = *arr;
// 2.再把后面的所有元素往前移动一个位置,同样下边是从0开始,所以最后一个元素是(长度-1)
// 并且我只需要要倒数第二个元素等于最后一个元素就实现了全部元素整体向前移动一个位置
int j = 0;
for (j = 0; j < m-1; j++)
{
*(arr + j) = *(arr + j + 1);
}
// 3.将临时变量里面的字符赋值给最后一个单元
*(arr + m - 1) = temp;
}
}
值得注意的是,我们相当于每次都是对首元素进行操作的,后面的每一个元素都要随着第一个元素的旋转而进行移动,感觉是比较繁琐的,但这恰恰体现了面向过程编程的乐趣,让你对操作的每一步都很了解。
2.3:测试功能的实现情况
printf("左旋转num个字符后的字符串:%s\n", arr);
3.全部代码
#define _CRT_SECURE_NO_WARNINGS
//左旋转num个字符串
#include<stdio.h>
#include<assert.h>
void left_move(char* arr, int n, int m) // char arr[] 可互换 char* arr 因为都是首元素地址
{
assert(arr); // 只要传进来的是指针就断言一下
int i = 0;
for (i = 0; i < n; i++)
{
// 1.先把第一个字符存在临时变量里
char temp = *arr;
// 2.再把后面的元素往前移动一个位置
int j = 0;
for (j = 0; j < m-1; j++)
{
*(arr + j) = *(arr + j + 1);
}
// 3.将临时变量里面的字符赋值给最后一个位置
*(arr + m - 1) = temp;
}
}
int main()
{
char arr[] = "abcdef";
int num = 0;
int l = 0;
printf("请输入旋转个数\n");
scanf("%d", &num);
l = strlen(arr);
left_move(arr, num, l);
printf("旋转后的字符串:%s\n", arr);
return 0;
}