怎么在C语言中用递归方式实现数组的局部逆序

avatar
作者
筋斗云
阅读量:0

下面是一个示例代码,演示了如何在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函数,并打印出局部逆序后的数组。

广告一刻

为您即时展示最新活动产品广告消息,让您随时掌握产品活动新动态!