题目描述:
矩阵显然需要用到C语言的二维数组来解决
这里要注意,输入的时候是一个矩阵输入完了过后再输入另一个矩阵,并且一次输入只能读取一个数,这样我们就需要一个for循环来依次分别对啊,b两个数进行输入。
笔者在写这个代码之前也是非常的纠结这个循环应该怎么去建立,知道我自己亲手用笔去画了一下这个过程后再真正发现这个代码里面的规律
我们通过计算结果数列的一个内部过程来推算整体,可以发现如下规律
我们纵向来看这些数的时候可以发现很多规律,在分别单独计算c中每一个数的时候,我们在其中去分别寻找有没有某些列是完全相同的数字,这样我们就可以把他们作为最外层的循环,找完相同的过后再去找那些不相同的,可以发现都是以同样的递增方式并且是同样的数字进行递增,那么这样我们就将其作为循环的最内层,即k层
这里的输出也需要注意,输出有每三个换行的情况,需要格外注意一下。
源代码:
#include
int main()
{
int i = 0;
int j = 0;
int k = 0;
int a[3][3] = { 0 };
int b[3][3] = { 0 };
int c[3][3] = { 0 };
for (i = 0; i <= 2; i++)
{
for (j = 0; j <= 2; j++)
{
scanf("%d", &a[i][j]);//注意这里的取地址符号不能掉
}
}
for (i = 0; i <= 2; i++)
{
for (j = 0; j <= 2; j++)
{
scanf("%d", &b[i][j]);
}
}
for (i = 0; i <= 2; i++)
{
for (j = 0; j <= 2; j++)
{
for (k = 0; k <= 2; k++)
{
c[i][j] = c[i][j] + a[i][k] * b[k][j];
}
}
}
for (i = 0; i <= 2; i++)
{
for (j = 0; j <= 2; j++)
{
printf("%d ", c[i][j]);
}
printf("n");
}
return 0;
}



