有n个整数,使前面各数顺序向后移m个位置,最后m个数变成最前面m个数,见图。写一函数实现以上功能,在主函数中输入n个整数和输出调整后的n个数。(此题请用指针的知识完成)
时间: 2023-04-13 15:04:47 浏览: 48
题目中要求实现一个函数,将一个长度为n的整数数组中的元素向后移动m个位置,并且最后m个元素变成最前面m个元素。这个函数可以使用指针来实现。
函数的参数应该包括一个指向整数数组的指针,数组的长度n和向后移动的位置m。函数的实现可以分为两个步骤:
1. 将后面m个元素复制到一个临时数组中。
2. 将前面n-m个元素向后移动m个位置,并将临时数组中的元素复制到最前面m个位置。
函数的实现如下:
```c
void shift_array(int *arr, int n, int m) {
int temp[m];
for (int i = n - m; i < n; i++) {
temp[i - (n - m)] = arr[i];
}
for (int i = n - 1; i >= m; i--) {
arr[i] = arr[i - m];
}
for (int i = 0; i < m; i++) {
arr[i] = temp[i];
}
}
```
在主函数中,可以先读入n和m,然后再读入n个整数,调用函数进行移动,最后输出调整后的n个数。主函数的实现如下:
```c
int main() {
int n, m;
scanf("%d%d", &n, &m);
int arr[n];
for (int i = 0; i < n; i++) {
scanf("%d", &arr[i]);
}
shift_array(arr, n, m);
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
```