有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数。编写函数实现上述功能,在主函数中输入n个整数,并输出调整后的n个数。
时间: 2023-12-20 21:51:35 浏览: 59
以下是一个实现上述功能的函数:
```c
#include <stdio.h>
void shift_array(int arr[], int n, int m) {
// 将前 n - m 个元素向后移动 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] = arr[n - m + i];
}
}
int main() {
int n, m;
printf("Please enter the number of integers: ");
scanf("%d", &n);
printf("Please enter the number of positions to shift: ");
scanf("%d", &m);
int arr[n];
printf("Please enter %d integers:\n", n);
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
shift_array(arr, n, m);
printf("Shifted array:\n");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```
这个函数接受三个参数:整数数组 `arr`,数组长度 `n`,和需要向后移动的位置数 `m`。函数先将前 `n-m` 个元素向后移动 `m` 个位置,然后将最后 `m` 个元素移动到最前面。在主函数中,我们首先从用户输入中获取数组长度 `n` 和需要移动的位置数 `m`,然后输入 `n` 个整数,调用 `shift_array` 函数进行数组移动,最后输出调整后的数组。
阅读全文