可以通過指針來實現(xiàn)數(shù)組逆序。下面是一個示例代碼:
#include <stdio.h>
void reverseArray(int *arr, int size) {
int *start = arr; // 指向數(shù)組的第一個元素
int *end = arr + size - 1; // 指向數(shù)組的最后一個元素
while (start < end) {
// 交換start和end指向的元素
int temp = *start;
*start = *end;
*end = temp;
// 移動start和end指針
start++;
end--;
}
}
int main() {
int arr[] = {1, 2, 3, 4, 5};
int size = sizeof(arr) / sizeof(arr[0]);
printf("原始數(shù)組:");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
reverseArray(arr, size);
printf("\n逆序數(shù)組:");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
return 0;
}
運行結果:
原始數(shù)組:1 2 3 4 5
逆序數(shù)組:5 4 3 2 1
在上述代碼中,通過使用指針變量start
和end
來分別指向數(shù)組的第一個元素和最后一個元素,然后使用while循環(huán)將兩個指針向中間移動,并交換它們指向的元素,從而實現(xiàn)數(shù)組的逆序。