在C语言中,要实现多维数组的逆序排列,可以通过循环遍历数组并交换元素的方式来实现。以下是一个示例,展示了如何实现二维数组的逆序排列:
#includevoid 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
函数进行逆序排列,然后输出原始数组和逆序排列后的数组。
注意:这个示例仅适用于二维数组,对于更高维度的数组,需要使用递归或其他方法来实现逆序排列。