在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
函数进行逆序排列,然后输出原始数组和逆序排列后的数组。
注意:这个示例仅适用于二维数组,对于更高维度的数组,需要使用递归或其他方法来实现逆序排列。