可以使用兩個指針,一個指向數組的第一個元素,一個指向數組的最后一個元素,然后交換兩個指針指向的元素,再分別向中間移動指針,直到兩個指針相遇為止。具體實現如下:
#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
這樣就實現了對數組的倒序排列。