可以使用两个指针,一个指向数组的第一个元素,一个指向数组的最后一个元素,然后交换两个指针指向的元素,再分别向中间移动指针,直到两个指针相遇为止。具体实现如下:
#include <stdio.h>
void reverseArray(int arr[], int n) {
int start = 0;
int end = n - 1;
while (start < end) {
// 交换start指向的元素和end指向的元素
int temp = arr[start];
arr[start] = arr[end];
arr[end] = temp;
// 分别向中间移动指针
start++;
end--;
}
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int n = sizeof(arr) / sizeof(arr[0]);
printf("原数组:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
reverseArray(arr, n);
printf("\n倒序排列后的数组:");
for (int i = 0; i < n; i++) {
printf("%d ", arr[i]);
}
return 0;
}
输出结果为:
原数组:1 2 3 4 5
倒序排列后的数组:5 4 3 2 1
这样就实现了对数组的倒序排列。