C语言中如何实现多维数组的逆序排列

avatar
作者
筋斗云
阅读量:0

在C语言中,要实现多维数组的逆序排列,可以通过循环遍历数组并交换元素的方式来实现。以下是一个示例,展示了如何实现二维数组的逆序排列:

#include<stdio.h>  void reverse_2d_array(int arr[][3], int rows, int cols) {     for (int i = 0; i< rows / 2; i++) {         for (int j = 0; j< cols; j++) {             // 交换第i行和第rows-1-i行的元素             int temp = arr[i][j];             arr[i][j] = arr[rows - 1 - i][j];             arr[rows - 1 - i][j] = temp;         }     } }  int main() {     int arr[][3] = {         {1, 2, 3},         {4, 5, 6},         {7, 8, 9},         {10, 11, 12}     };     int rows = sizeof(arr) / sizeof(arr[0]);     int cols = sizeof(arr[0]) / sizeof(arr[0][0]);      printf("原始二维数组:\n");     for (int i = 0; i< rows; i++) {         for (int j = 0; j< cols; j++) {             printf("%d ", arr[i][j]);         }         printf("\n");     }      reverse_2d_array(arr, rows, cols);      printf("逆序排列后的二维数组:\n");     for (int i = 0; i< rows; i++) {         for (int j = 0; j< cols; j++) {             printf("%d ", arr[i][j]);         }         printf("\n");     }      return 0; } 

这个示例中,reverse_2d_array函数接收一个二维数组、行数和列数作为参数,然后通过循环遍历数组并交换元素的方式实现逆序排列。在main函数中,我们定义了一个二维数组并调用reverse_2d_array函数进行逆序排列,然后输出原始数组和逆序排列后的数组。

注意:这个示例仅适用于二维数组,对于更高维度的数组,需要使用递归或其他方法来实现逆序排列。

广告一刻

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