溫馨提示×

怎么在C語言中用遞歸方式實現數組的局部逆序

小億
103
2024-05-27 10:06:15
欄目: 編程語言

下面是一個示例代碼,演示了如何在C語言中使用遞歸方式實現數組的局部逆序:

#include <stdio.h>

void reverseArray(int arr[], int start, int end) {
    if (start >= end) {
        return;
    }
    
    // 交換數組中的兩個元素
    int temp = arr[start];
    arr[start] = arr[end];
    arr[end] = temp;
    
    // 遞歸調用,繼續對剩余部分進行局部逆序
    reverseArray(arr, start + 1, end - 1);
}

int main() {
    int arr[] = {1, 2, 3, 4, 5};
    int n = sizeof(arr) / sizeof(arr[0]);
    
    int start = 1; // 局部逆序的起始位置
    int end = 3; // 局部逆序的結束位置
    
    reverseArray(arr, start, end);
    
    printf("局部逆序后的數組:");
    for (int i = 0; i < n; i++) {
        printf("%d ", arr[i]);
    }
    
    return 0;
}

在上面的示例中,我們定義了一個reverseArray函數,該函數接受一個數組、局部逆序的起始位置和結束位置作為參數。在函數中,我們首先交換起始位置和結束位置的元素,然后遞歸調用reverseArray函數對剩余部分進行局部逆序。最后,我們在主函數中調用reverseArray函數,并打印出局部逆序后的數組。

0
亚洲午夜精品一区二区_中文无码日韩欧免_久久香蕉精品视频_欧美主播一区二区三区美女