c語(yǔ)言數(shù)組倒序排列怎么實(shí)現(xiàn)

小億
159
2023-11-29 15:28:39

可以使用兩個(gè)指針,一個(gè)指向數(shù)組的第一個(gè)元素,一個(gè)指向數(shù)組的最后一個(gè)元素,然后交換兩個(gè)指針指向的元素,再分別向中間移動(dòng)指針,直到兩個(gè)指針相遇為止。具體實(shí)現(xiàn)如下:

#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;
        // 分別向中間移動(dòng)指針
        start++;
        end--;
    }
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int n = sizeof(arr) / sizeof(arr[0]);

    printf("原數(shù)組:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    reverseArray(arr, n);

    printf("\n倒序排列后的數(shù)組:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }

    return 0;
}

輸出結(jié)果為:

原數(shù)組:1 2 3 4 5 
倒序排列后的數(shù)組:5 4 3 2 1 

這樣就實(shí)現(xiàn)了對(duì)數(shù)組的倒序排列。

0