#include <stdio.h>
void array_mul(int (*x)[2], int (*y)[2], int (*ans)[2]);
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;
}
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];
}
printf("%d行%d列目の値は%d\n", i
+ 1, j
+ 1, ans
[i
][j
]); }
}
}
I2luY2x1ZGUgPHN0ZGlvLmg+Cgp2b2lkIGFycmF5X211bChpbnQgKCp4KVsyXSwgaW50ICgqeSlbMl0sIGludCAoKmFucylbMl0pOwoKaW50IG1haW4odm9pZCkKewogICAgaW50IHhbMl1bMl0gPSB7IHsxLCAyfSwgezMsIDR9IH07CiAgICBpbnQgeVsyXVsyXSA9IHsgezEsIDJ9LCB7MywgNH0gfTsKICAgIGludCBhbnNbMl1bMl07CgogICAgYXJyYXlfbXVsKHgsIHksIGFucyk7CgogICAgcmV0dXJuIDA7Cn0KCnZvaWQgYXJyYXlfbXVsKGludCAoKngpWzJdLCBpbnQgKCp5KVsyXSwgaW50ICgqYW5zKVsyXSkKewogICAgZm9yIChpbnQgaSA9IDA7IGkgPCAyOyBpKyspIHsKICAgICAgICBmb3IgKGludCBqID0gMDsgaiA8IDI7IGorKykgewogICAgICAgICAgICBhbnNbaV1bal0gPSAwOwogICAgICAgICAgICBmb3IgKGludCBrID0gMDsgayA8IDI7IGsrKykgewogICAgICAgICAgICAgICAgYW5zW2ldW2pdICs9IHhbaV1ba10gKiB5W2tdW2pdOwogICAgICAgICAgICB9CiAgICAgICAgICAgIHByaW50ZigiJWTooYwlZOWIl+ebruOBruWApOOBryVkXG4iLCBpICsgMSwgaiArIDEsIGFuc1tpXVtqXSk7CiAgICAgICAgfQogICAgfQp9Cg==