要实现C语言逆序存放数组,可以使用两个指针分别指向数组的首尾元素,然后交换它们的值,然后向中间移动指针,重复交换操作,直到指针相遇为止。以下是一个示例代码:
#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("Original array: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
reverseArray(arr, size);
printf("Reversed array: ");
for (int i = 0; i < size; i++) {
printf("%d ", arr[i]);
}
printf("\n");
return 0;
}
此代码将输出:
Original array: 1 2 3 4 5
Reversed array: 5 4 3 2 1
在reverseArray
函数中,start
指针初始指向数组的第一个元素,end
指针初始指向数组的最后一个元素。通过交换arr[start]
和arr[end]
的值,然后向中间移动指针,重复交换操作,直到指针相遇为止。