c语言逆序存放数组怎么实现

855
2023/12/3 10:41:48
栏目: 编程语言
开发者测试专用服务器限时活动,0元免费领,库存有限,领完即止! 点击查看>>

要实现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]的值,然后向中间移动指针,重复交换操作,直到指针相遇为止。

辰迅云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>

推荐阅读: c语言怎么计算字符数组的长度