可以通过指针来实现数组逆序。下面是一个示例代码:
#include <stdio.h>
void reverseArray(int *arr, int size) {
int *start = arr; // 指向数组的第一个元素
int *end = arr + size - 1; // 指向数组的最后一个元素
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("原始数组:");
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
在上述代码中,通过使用指针变量start
和end
来分别指向数组的第一个元素和最后一个元素,然后使用while循环将两个指针向中间移动,并交换它们指向的元素,从而实现数组的逆序。