有n个整数,使前面各数顺序向后移m个位置,最后m 个数变成最前面m 个数,见图 8.43。写一函数实现以上功能, 在主函数中输入n个整数和输出调整后的n个数。
时间: 2023-12-20 16:22:48 浏览: 54
好的,这是一个比较经典的数组操作问题。下面是实现该功能的函数代码:
```c
void shift_array(int arr[], int n, int m) {
int temp[m];
// 先保存最后的 m 个数
for (int i = n - m; i < n; i++) {
temp[i - (n - m)] = arr[i];
}
// 把前面的数依次向后移 m 个位置
for (int i = n - m - 1; i >= 0; i--) {
arr[i + m] = arr[i];
}
// 把最后的 m 个数放到最前面
for (int i = 0; i < m; i++) {
arr[i] = temp[i];
}
}
```
该函数接受三个参数,分别是整数数组 `arr`、数组长度 `n` 和向后移动的位置数 `m`。函数先创建一个临时数组 `temp`,用来保存最后的 `m` 个数。然后通过两个循环来实现移动数组的操作,最后把临时数组中的元素放到最前面即可。
以下是一个简单的示例程序,演示了如何调用该函数:
```c
#include <stdio.h>
void shift_array(int arr[], int n, int m);
int main() {
int n, m;
printf("请输入整数个数 n 和向后移动的位置数 m:");
scanf("%d%d", &n, &m);
int arr[n];
printf("请输入 %d 个整数:", n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
shift_array(arr, n, m);
printf("调整后的数组为:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
你可以将上面两段代码放到一个文件中编译运行,输入一些测试数据,就可以得到相应的结果了。
阅读全文