可以通过指针来实现数组逆序。下面是一个示例代码:
#includevoid 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循环将两个指针向中间移动,并交换它们指向的元素,从而实现数组的逆序。