尝试运行此代码时,我遇到了分段错误问题:
#include<stdio.h>
#include<stdlib.h>
int mallocMatrix (int ***matrix, int A, int B) {
int i;
*matrix=(int**)malloc(sizeof(int*)*B);
for(i=0;i<A;i++)
(*matrix)[i]=(int*)malloc(sizeof(int)*A);
};
void fillMatrix (int ***matrix, int A, int B) {
int i, j;
for(i=0;i<B;i++)
{
for(j=0;j<A;j++)
{
printf("Matrix[%d][%d]: ",i+1,j+1);
scanf("%d", &(*matrix)[i][j]);
}
}
};
void displayMatrix (int ***matrix, int A, int B) {
int i, j;
printf ("\n");
for(i=0;i<B;i++)
{
for(j=0;j<A;j++)
{
printf ("%d ", (*matrix)[i][j]);
}
printf ("\n");
}
};
int main(){
int **matrix;
int **matrix_two;
int **matrix_three;
int a, b, c, d;
printf ("[1st matrix] number of columns:");
scanf ("%d", &a);
printf ("[1st matrix] number of rows:");
scanf ("%d", &b);
mallocMatrix (&matrix, a, b);
fillMatrix (&matrix, a, b);
printf ("[2nd matrix] number of columns:");
scanf ("%d", &c);
printf ("[2nd matrix] number of rows:");
scanf ("%d", &d);
if (a==d)
{
mallocMatrix (&matrix_two, c, d);
fillMatrix (&matrix_two, c, d);
}
else
{
printf ("The number of columns of the 1st. matrix must be equal to the number of rows of the 2nd. matrix");
return -1;
}
displayMatrix (&matrix, a, b);
displayMatrix (&matrix_two, c, d);
mallocMatrix (&matrix_three, b, c);
/* multiplication */
int i, j, k;
for(i = 0; i < b; i++)
{
for(j = 0; j < c; j++)
{
for(k = 0; k < b; k++)
{
matrix_three[i][j] = matrix_three[i][j] + matrix[i][k] * matrix_two[k][j];
}
}
}
/* end of multiplication */
displayMatrix (&matrix_three, b, c);
}
代码签名/ 乘法 /后弹出问题。例如: - 第一个矩阵是2x2, - 第二次3x2。 我期待结果为3x2矩阵,BUT代码在尝试到达第三列时给出了2x2矩阵和分段错误。请指出错误
答案 0 :(得分:0)
我想我在mallocMatrix中发现了你的错误:
for(i=0;i<A;i++)
(*matrix)[i]=(int*)malloc(sizeof(int)*A);
循环条件错误你说B是行数,所以对于每个rouw你必须分配一个A元素数组,所以循环应该是:
for(i=0;i<B;i++)
(*matrix)[i]=(int*)malloc(sizeof(int)*A);
所以当你尝试3x2时,第三行永远不会被初始化,因为你的循环只迭代了2次,当你尝试填充最后一行时崩溃