我正在尝试在 C 中完成对稀疏矩阵的分配。我有一个作为值和坐标列表的稀疏矩阵,并将其转换为耶鲁格式。
我遇到了一个以前似乎没有人见过的奇怪的内存分配问题。我的代码是:
yale* convertMatrix(matrix_list* input){
int matrix_elements = input->elements;
int matrix_rows = input->m;
yale* yale = (struct y*)calloc(1, sizeof(yale));
int* A = (int*)calloc(matrix_elements, sizeof(int));
int* IA = (int*)calloc(matrix_rows + 1, sizeof(int));
int* JA = (int*)calloc(matrix_elements, sizeof(int));
printf("%d elements\n",matrix_elements);
yale->A = A; // Value
yale->IA = IA; // Row (X)
yale->JA = JA; // Column (Y)
yale->elements = matrix_elements;
yale->m = matrix_rows;
yale->n = input->n;
list* tmp_list = input->first;
for(int i = 0, j = 0, tmp_y = 0; i < matrix_elements && tmp_list!=NULL; i++){
printf("Input Value: %d \n",tmp_list->point.value);
A[i] = tmp_list->point.value;
// Initialise the first row
if(i == 0) IA[0] = tmp_list->point.x;
else{
// Add a new row index
if(tmp_y != tmp_list->point.x){
j++;
IA[j] = i;
tmp_y = tmp_list->point.x;
}
}
JA[i] = tmp_list->point.y;
tmp_list = tmp_list->next;
}
for(int i = 0; i < matrix_elements; i++)
printf("%d,",yale->A[i]);
printf("\n");
for(int i = 0; i < matrix_rows + 1; i++)
printf("%d,",yale->IA[i]);
printf("\n");
for(int i = 0; i < matrix_elements; i++)
printf("%d,",yale->JA[i]);
return yale;
}
这是耶鲁的结构:
typedef struct y{
int n;
int m;
int elements;
int *IA;
int *JA;
int *A;
} yale;
但是程序在循环的第一次迭代中在第一个相关的 printf 处出现段错误。
printf("%d,",yale->A[i]);
我是肯定的:matrix_elements 是一个整数(在我的测试用例中为 9) matrix_rows 是一个整数 A / IA / JA 都填充了正确的值(如果你在 printf 中将 yale->A 换成 A,它工作正常)。直接将数组调用到结构指针不会影响结果。Mallocing,callocing,而不是类型转换,都没有效果。
感谢 Xcode 和 gdb,我还可以在段错误的地方看到这一点。结构指针似乎不指向数组