C语言:对于有n个整数的数组,使其前面各数顺序向后移m个位置,让最后m个数变成最前面的m个数。给出代码
时间: 2024-06-13 17:08:52 浏览: 71
有n个整数,使其前面各数顺序向后移m个位置,最后m个数变成最前面的m个数.
以下是C语言实现的代码,可以实现将数组中前面的数向后移动m个位置,使得最后m个数变成最前面的m个数:
```c
#include <stdio.h>
void reverse(int arr[], int start, int end) {
while (start < end) {
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
start++;
end--;
}
}
void rotate(int arr[], int n, int m) {
reverse(arr, 0, n - 1);
reverse(arr, 0, m - 1);
reverse(arr, m, n - 1);
}
int main() {
int arr[] = {1, 2, 3, 4, 5, 6, 7};
int n = sizeof(arr) / sizeof(arr[0]);
int m = 3;
rotate(arr, n, m);
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
```
其中,reverse函数用于翻转数组中指定范围内的元素,rotate函数用于将数组中前面的数向后移动m个位置,最后输出移动后的数组。
阅读全文