如何用C语言实现一维数组元素的逆序存放操作?
时间: 2024-11-03 13:17:16 浏览: 74
在C语言中,要实现一维数组元素的逆序存放,可以使用两个指针,一个指向数组的开始,另一个指向数组的结束。然后通过交换这两个指针所指向的元素,逐渐向中间移动,直到它们相遇。下面是一个简单的示例:
```c
#include <stdio.h>
void reverseArray(int arr[], int size) {
if (size > 1) { // 避免空数组
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 myArray[] = {1, 2, 3, 4, 5};
int length = sizeof(myArray) / sizeof(myArray[0]);
printf("Original array: ");
for (int i = 0; i < length; i++) {
printf("%d ", myArray[i]);
}
reverseArray(myArray, length);
printf("\nReversed array: ");
for (int i = 0; i < length; i++) {
printf("%d ", myArray[i]);
}
return 0;
}
```
在这个例子中,`reverseArray`函数接受一个整型数组和它的长度,然后内部通过循环实现了逆序存放。运行`main`函数可以看到原始数组和逆序后的数组。
阅读全文