使用指针在c中乘以矩阵
Multiplying matrices in c using pointers
当我输入两个矩阵时,结果矩阵没有显示正确的答案,是我的算法错误还是我不应该那样使用指针?
请帮忙!
main() {
int a[3][3],b[3][3],c[3][3],*p[3],*q[3],*r[3],j1=0;
// 1st Matrix
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
scanf("%d",&a[i][j]);
}
}
// 2nd matrix
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
scanf("%d",&b[i][j]);
}
}
// Assigning pointers
for(int i=0;i<3;i++) p[i]=&a[i][0];
for(int i=0;i<3;i++) q[i]=&b[i][0];
for(int i=0;i<3;i++) r[i]=&c[i][0];
// Resultant Matrix
for(int i=0;i<3;i++){
*(*(r+i)+j1) = 0;
for(j1=0;j1<3;j1++){
printf("%d\t",*(*(r+i)+j1));
*(*(r+i)+j1) += *(*(p+i)+j1) * *(*(q+j1)+i);
}
j1 = 0;
}
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
printf("%d\t",c[i][j]);
}
printf("\n");
}
}
您的循环遍历二维并对数组 a
和 b
执行逐元素乘法与 b
转置。我怀疑您想执行矩阵乘法而不是逐元素乘法。为此,您需要三个循环:
- 两个循环通过
c
. 的行和列迭代索引 i
和 j
- 一个循环通过
a
和 b
的公共维度迭代一些变量,比如 k
,并将 a[i][k]
的乘积与 b[k][j]
相加.
当我输入两个矩阵时,结果矩阵没有显示正确的答案,是我的算法错误还是我不应该那样使用指针? 请帮忙!
main() {
int a[3][3],b[3][3],c[3][3],*p[3],*q[3],*r[3],j1=0;
// 1st Matrix
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
scanf("%d",&a[i][j]);
}
}
// 2nd matrix
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
scanf("%d",&b[i][j]);
}
}
// Assigning pointers
for(int i=0;i<3;i++) p[i]=&a[i][0];
for(int i=0;i<3;i++) q[i]=&b[i][0];
for(int i=0;i<3;i++) r[i]=&c[i][0];
// Resultant Matrix
for(int i=0;i<3;i++){
*(*(r+i)+j1) = 0;
for(j1=0;j1<3;j1++){
printf("%d\t",*(*(r+i)+j1));
*(*(r+i)+j1) += *(*(p+i)+j1) * *(*(q+j1)+i);
}
j1 = 0;
}
for(int i=0;i<3;i++){
for(int j=0;j<3;j++){
printf("%d\t",c[i][j]);
}
printf("\n");
}
}
您的循环遍历二维并对数组 a
和 b
执行逐元素乘法与 b
转置。我怀疑您想执行矩阵乘法而不是逐元素乘法。为此,您需要三个循环:
- 两个循环通过
c
. 的行和列迭代索引 - 一个循环通过
a
和b
的公共维度迭代一些变量,比如k
,并将a[i][k]
的乘积与b[k][j]
相加.
i
和 j