该代码是使用the column of A and the row of B must be the same
的属性来构造的,以查找矩阵乘积。
不使用动态分配的情况下乘以2D矩阵可以用,但是使用动态分配后就不行了,所以我查地址,地址相差30
。
int *matrixMulti(int N, int M, int L, int *A, int *B)
{
int *Mat = (int *)malloc(N * L * sizeof(int));
for (int i = 0; i < N; i++)
{
for (int j = 0; j < L; j++)
{
*(Mat + i * M + j) = 0;
for (int k = 0; k < M; k++)
{
*(Mat + i * M + j) += A[i * M + k] * B[k * M + j];
}
printf("Mat[%d][%d] Mat[i][j] %d Mat address : %p \n", i, j, *(Mat + i * M + j), Mat);
printf("\n");
}
}
return Mat;
}
int main()
{
int N, M, L;
printf("input N M L\n ");
scanf("%d %d %d", &N, &M, &L);
int *A = (int *)malloc(N * M * sizeof(int));
int *B = (int *)malloc(L * M * sizeof(int));
int *S = (int *)malloc(N * L * sizeof(int));
input(N, M, A);
Array_print(N, M, A);
input(M, L, B);
Array_print(M, L, B);
S = matrixMulti(N, M, L, A, B);
printf("\n S address %p\n", matrixMulti(N, M, L, A, B)); ////////////////////////// ---> A
printf("\n S address %p\n", S); ////////////////////////// ---> A-30
// Array_print(N, L, matrixMulti(N, M, L, A, B));
free(A);
free(B);
free(S);
return 0;
}
最初,当只传递和接收arrays
时,矩阵乘法也正常输出,但当更改为pointers
时,它变得奇怪。
产出
S地址0x159f04120
S地址0x159f040f0
预期
S地址0x159f04120
S地址0x159f04120
完整代码here
1条答案
按热度按时间lf5gs5x21#
这是matrixMulti的简化版本
你会看到它分配内存并返回一个指针。
如果你调用它两次,你会在不同的地址得到两个不同的分配
编辑
注意这里
S现在包含matrixMulti. Ie Mat返回的值
S不包含matrixMulti的地址