阅读量:0
可以使用两个指针,一个指向数组的第一个元素,一个指向数组的最后一个元素,然后交换两个指针指向的元素,再分别向中间移动指针,直到两个指针相遇为止。具体实现如下:
#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
这样就实现了对数组的倒序排列。