C 言語の 2 次元配列の行と列の入れ替えを行う方法
二行行列の入れ替えを実行するには、二重ループを使用できます。手順は次のとおりです。
- 転置結果を格納するために二次元配列を新たに定義します。
- 2重ループで元の二次元配列の各要素を走査する.
- 元の配列の行インデックスを新しい配列の列インデックスとして、元の配列の列インデックスを新しい配列の行インデックスとして、対応する要素値を新しい配列にコピーします。
- 結果、新しい配列の行数は元の配列の列数とイコールで、新しい配列の列数は元の配列の行数とイコール。
次に示すのはサンプルコードです。
#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
行列を入れ替え後、行の数は元の列に一致し、列の数も元の行の数と同じになる。