#include <stdio.h>
void array_mul(int (*x)[2], int (*y)[2], int (*ans)[2])
{
int i, j, k;
// 2×2 行列の掛け算
for (i = 0; i < 2; i++) {
for (j = 0; j < 2; j++) {
ans[i][j] = 0;
for (k = 0; k < 2; k++) {
ans[i][j] += x[i][k] * y[k][j];
}
}
}
// 結果表示
printf("Result matrix (ans):\n"); for (i = 0; i < 2; i++) {
for (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+Cgp2b2lkIGFycmF5X211bChpbnQgKCp4KVsyXSwgaW50ICgqeSlbMl0sIGludCAoKmFucylbMl0pCnsKICAgIGludCBpLCBqLCBrOwoKICAgIC8vIDLDlzIg6KGM5YiX44Gu5o6b44GR566XCiAgICBmb3IgKGkgPSAwOyBpIDwgMjsgaSsrKSB7CiAgICAgICAgZm9yIChqID0gMDsgaiA8IDI7IGorKykgewogICAgICAgICAgICBhbnNbaV1bal0gPSAwOwogICAgICAgICAgICBmb3IgKGsgPSAwOyBrIDwgMjsgaysrKSB7CiAgICAgICAgICAgICAgICBhbnNbaV1bal0gKz0geFtpXVtrXSAqIHlba11bal07CiAgICAgICAgICAgIH0KICAgICAgICB9CiAgICB9CgogICAgLy8g57WQ5p6c6KGo56S6CiAgICBwcmludGYoIlJlc3VsdCBtYXRyaXggKGFucyk6XG4iKTsKICAgIGZvciAoaSA9IDA7IGkgPCAyOyBpKyspIHsKICAgICAgICBmb3IgKGogPSAwOyBqIDwgMjsgaisrKSB7CiAgICAgICAgICAgIHByaW50ZigiJWQgIiwgYW5zW2ldW2pdKTsKICAgICAgICB9CiAgICAgICAgcHJpbnRmKCJcbiIpOwogICAgfQp9CgppbnQgbWFpbih2b2lkKQp7CiAgICBpbnQgeFsyXVsyXSA9IHsKICAgICAgICB7MSwgMn0sCiAgICAgICAgezMsIDR9CiAgICB9OwoKICAgIGludCB5WzJdWzJdID0gewogICAgICAgIHsxLCAyfSwKICAgICAgICB7MywgNH0KICAgIH07CgogICAgaW50IGFuc1syXVsyXTsKCiAgICBhcnJheV9tdWwoeCwgeSwgYW5zKTsKCiAgICByZXR1cm4gMDsKfQo=