可以利用兩個指針來實現數組的逆置。一個指向數組的起始位置,一個指向數組的末尾位置,然后交換兩個指針指向的元素,然后分別向數組中心移動指針,再進行交換,重復這個過程直到兩個指針相遇。
下面是一個示例代碼:
#include <stdio.h>
void reverseArray(int arr[], int size) {
int start = 0; // 起始位置指針
int end = size - 1; // 結束位置指針
while (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 size = sizeof(arr) / sizeof(arr[0]);
printf("原始數組:");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
reverseArray(arr, size);
printf("\n逆置后數組:");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
輸出結果為:
原始數組:1 2 3 4 5
逆置后數組:5 4 3 2 1