c语言二维数组行列互换怎么实现
要实现二维数组的行列互换,可以通过两层循环来完成。具体步骤如下:
- 定义一个新的二维数组,用于存储行列互换后的结果。
- 使用两层循环遍历原始二维数组的每个元素。
- 将原始数组的行索引作为新数组的列索引,将原始数组的列索引作为新数组的行索引,将对应的元素值复制到新数组中。
- 最后,新数组的行数等于原始数组的列数,新数组的列数等于原始数组的行数。
下面是一个示例代码:
#include <stdio.h>
#define ROWS 3
#define COLS 4
void transpose(int arr[][COLS], int transposed[][ROWS]) {
for (int i = 0; i < ROWS; i++) {
for (int j = 0; j < COLS; j++) {
transposed[j][i] = arr[i][j];
}
}
}
int main() {
int arr[ROWS][COLS] = {{1, 2, 3, 4},
{5, 6, 7, 8},
{9, 10, 11, 12}};
int transposed[COLS][ROWS];
transpose(arr, transposed);
printf("Original array:\n");
for (int i = 0; i < ROWS; i++) {
for (int j = 0; j < COLS; j++) {
printf("%d ", arr[i][j]);
}
printf("\n");
}
printf("\nTransposed array:\n");
for (int i = 0; i < COLS; i++) {
for (int j = 0; j < ROWS; j++) {
printf("%d ", transposed[i][j]);
}
printf("\n");
}
return 0;
}
运行该代码,输出结果为:
Original array:
1 2 3 4
5 6 7 8
9 10 11 12
Transposed array:
1 5 9
2 6 10
3 7 11
4 8 12
可以看到,原始数组的行列互换后,得到的新数组的行数等于原始数组的列数,新数组的列数等于原始数组的行数。
版权声明
本文仅代表作者观点,不代表米安网络立场。
上一篇:服务器被攻击了怎么解决 下一篇:JAVA如何创建类的对象
发表评论:
◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。