马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
小甲鱼第25节课的课后作业,计算两个矩阵相乘,这是小甲鱼的答案#include <stdio.h>
int main()
{
int m, p, n;
int i, j, k, row;
// 定义第一个矩阵
printf("请输入第一个矩阵的尺寸(M * P):");
scanf("%d * %d", &m, &p);
int matrix_in_1[m][p];
// 定义第二个矩阵
printf("请输入第一个矩阵的尺寸(P * N):");
scanf("%d * %d", &p, &n);
int matrix_in_2[p][n];
// 初始化存放乘积的二维数组
// VAL数组不支持直接初始化操作
int matrix_out[m][n];
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
matrix_out[i][j] = 0;
}
}
// 让用户输入第一个矩阵
printf("请输入第一个矩阵的值:\n");
for (i = 0; i < m; i++)
{
for (j = 0; j < p; j++)
{
scanf("%d", &matrix_in_1[i][j]);
}
}
// 让用户输入第二个矩阵
printf("请输入第二个矩阵的值:\n");
for (i = 0; i < p; i++)
{
for (j = 0; j < n; j++)
{
scanf("%d", &matrix_in_2[i][j]);
}
}
// 计算乘积并保存
for (i = 0; i < m; i++)
{
for (j = 0; j < n; j++)
{
for (k = 0; k < p; k++)
{
matrix_out[i][j] += matrix_in_1[i][k] * matrix_in_2[k][j];
}
}
}
printf("计算结果如下:\n");
// row 取行数最大值
row = m > p ? m : p;
for (i = 0; i < row; i++)
{
printf("| ");
// 打印 matrix_in_1
for (j = 0; j < p; j++)
{
if (i < m)
{
printf("\b%d ", matrix_in_1[i][j]);
printf("|");
}
else
{
printf("\b\b\b ");
}
}
// 打印 * 号
if (i == row / 2)
{
printf(" * ");
}
else
{
printf(" ");
}
printf("| ");
// 打印 matrix_in_2
for (j = 0; j < n; j++)
{
if (i < p)
{
printf("\b%d ", matrix_in_2[i][j]);
printf("|");
}
else
{
printf("\b\b\b ");
}
}
// 打印 = 号
if (i == row / 2)
{
printf(" = ");
}
else
{
printf(" ");
}
// 打印 matrix_out
printf("| ");
for (j = 0; j < n; j++)
{
if (i < m)
{
printf("\b%d ", matrix_out[i][j]);
printf("|");
}
else
{
printf("\b\b\b ");
}
}
printf("\n");
}
return 0;
}
这是我的结果:#include <stdio.h>
int main()
{
int m,p,n;
int i,j,k;
int matrix_1[m][p];
int matrix_2[p][n];
int matrix_v[m][n];
printf("请输入第一个矩阵的尺寸(M * P):");
scanf("%d * %d",&m,&p);
printf("请输入第二个矩阵的尺寸(P * N):");
scanf("%d * %d",&p,&n);
for (i = 0;i < m;i++)
{
for (j = 0;j < n;j++)
{
matrix_v[i][j] = 0;
}
}
printf("请输入第一个矩阵的值:\n");
for (i = 0;i < m;i++)
{
for (j = 0;j < p;j++)
{
scanf("%d",&matrix_1[i][j]);
}
}
printf("请输入第二个矩阵的值:\n");
for (i = 0;i < p;i++)
{
for (j = 0;j < n;j++)
{
scanf("%d",&matrix_2[i][j]);
}
}
for (i = 0;i < m;i++)
{
for (j = 0;j < n;j++)
{
for (k = 0;k < p;k++)
{
matrix_v[i][j] += matrix_1[i][k] * matrix_2[k][j];
}
}
}
int row;//最大行数
row = m > p ? m : p;
for (i = 0;i < row;i++)
{
//打印第一个矩阵
if (i <= m)
{
printf("| ");
for (j = 0;j < p;j++)
{
printf("%d ",matrix_1[i][j]);
}
printf("|");
}
else
{
printf(" ");
for (j = 0;j < p;j++)
{
printf(" ");
}
printf(" ");
}
//打印第一个空隙
if (i == row / 2)
{
printf(" * ");
}
else
{
printf(" ");
}
//打印第二个矩阵
if (i <= p)
{
printf("| ");
for (j = 0;j < n;j++)
{
printf("%d ",matrix_2[i][j]);
}
printf("|");
}
else
{
printf(" ");
for (j = 0;j < n;j++)
{
printf(" ");
}
printf(" ");
}
//打印第二个空隙
if (i == row / 2)
{
printf(" = ");
}
else
{
printf(" ");
}
//打印结果矩阵
if (i <= m)
{
printf("| ");
for (j = 0;j < n;j++)
{
printf("%d ",matrix_v[i][j]);
}
printf("|");
}
else
{
printf(" ");
for (j = 0;j < n;j++)
{
printf(" ");
}
printf(" ");
}
printf("\n");
}
return 0;
}
可是我的程序得到的最后形式是正确的,可是矩阵的内容老是不对,不知道问题在哪,求大佬解答 |