#include <stdio.h>
void array_mul(int (*x)[2], int (*y)[2], int (*ans)[2]) {
for (int i = 0; i < 2; i++) { // 行ループ
for (int j = 0; j < 2; j++) { // 列ループ
ans[i][j] = 0;
for (int k = 0; k < 2; k++) { // 積の計算
ans[i][j] += x[i][k] * y[k][j];
}
}
}
// 結果表示
for (int i = 0; i < 2; i++) {
for (int j = 0; j < 2; j++) {
}
}
}
int main(void) {
int x[2][2] = {
{1, 2},
{3, 4}
};
int y[2][2] = {
{1, 2},
{3, 4}
};
int ans[2][2]; // 結果格納用
array_mul(x, y, ans);
return 0;
}
I2luY2x1ZGUgPHN0ZGlvLmg+Cgp2b2lkIGFycmF5X211bChpbnQgKCp4KVsyXSwgaW50ICgqeSlbMl0sIGludCAoKmFucylbMl0pIHsKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgMjsgaSsrKSB7ICAgICAgICAgLy8g6KGM44Or44O844OXCiAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCAyOyBqKyspIHsgICAgIC8vIOWIl+ODq+ODvOODlwogICAgICAgICAgICBhbnNbaV1bal0gPSAwOwogICAgICAgICAgICBmb3IgKGludCBrID0gMDsgayA8IDI7IGsrKykgeyAvLyDnqY3jga7oqIjnrpcKICAgICAgICAgICAgICAgIGFuc1tpXVtqXSArPSB4W2ldW2tdICogeVtrXVtqXTsKICAgICAgICAgICAgfQogICAgICAgIH0KICAgIH0KCiAgICAvLyDntZDmnpzooajnpLoKICAgIGZvciAoaW50IGkgPSAwOyBpIDwgMjsgaSsrKSB7CiAgICAgICAgZm9yIChpbnQgaiA9IDA7IGogPCAyOyBqKyspIHsKICAgICAgICAgICAgcHJpbnRmKCIlZCAiLCBhbnNbaV1bal0pOwogICAgICAgIH0KICAgICAgICBwcmludGYoIlxuIik7CiAgICB9Cn0KCmludCBtYWluKHZvaWQpIHsKICAgIGludCB4WzJdWzJdID0gewogICAgICAgIHsxLCAyfSwKICAgICAgICB7MywgNH0KICAgIH07CgogICAgaW50IHlbMl1bMl0gPSB7CiAgICAgICAgezEsIDJ9LAogICAgICAgIHszLCA0fQogICAgfTsKCiAgICBpbnQgYW5zWzJdWzJdOyAgLy8g57WQ5p6c5qC857SN55SoCgogICAgYXJyYXlfbXVsKHgsIHksIGFucyk7CgogICAgcmV0dXJuIDA7Cn0KCg==