どのように C 言語で配列を逆順に格納するのか

配列を逆順に格納するには、配列の先頭と末尾の要素を指す2つのポインタを使用し、次にそれらの値を交換してから、ポインタを中央まで移動し、交換操作を繰り返し、ポインタが会うまで繰り返します。以下にサンプルコードを示します。

#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]の値を入れ替え、ポインタを中央に向かって移動させ、ポインタが衝突するまで交換操作を繰り返します。

bannerAds