1

我在 C 中有一个矩阵,我想创建另一个比第一个矩阵具有双行的矩阵。那些添加的行我想要第一个矩阵的值,但符号改变。我试图理解动态分配,但我不明白我错在哪里。编译器说的错误是:“ invalid conversion from void* to int*"。这是我的代码:

#include <stdio.h>
#include<conio.h>
#include<stdlib.h>
int *extend_matrix=NULL;
int *matrix=NULL;
int *negative_matrix=NULL;
int main(void)
{
    int i,j,m,n;
    printf("Enter the number of rows and columns of  matrix\n");
    scanf("%d%d", &m, &n);
    int *matrix = (int *)malloc(m * n * sizeof(int));
    int *negative_matrix=(int*)malloc(m*n*sizeof(int));
    printf("Enter the elements of first matrix\n");
    for (  i = 0 ; i < m ; i++ )
        for ( j = 0 ; j < n ; j++ )
            scanf("%d", &matrix[i][j]);
    for(i = 0 ; i < m ; i++)
        for(j = 0 ; j < n ; j++)
            printf("the matrix is: \n",matrix[i][j]);
    negative_matrix=-matrix[i][j];
    for(i=0;i<m+m;i++)
        extend_matrix[i]=realloc(matrix[i],sizeof(int)*(m+m));
    for(j=0;j<n;j++)
        extend_matrix[j]=realloc(matrix[j],sizeof(int)*n);
    extend_matrix[i][j]=matrix[i][j]+negative_matrix[i][j];//how to concatenate them?
    getch();
    return 0;
}
4

1 回答 1

1

看来你有点糊涂了。让我写一个简短的示例代码

编辑:好的,去这里

在那里你会找到我的例子。我还没有完成它,但只是提供了关于如何完成它的输入。

请注意这一点:

从 66 到 68 行,我们有以下代码:

for (i = 0; i < rows; i++){
    free(first_matrix[i]);
}

这是因为我们矩阵的每个元素都是一个指针,它们都指向一个分配在堆上的数组。所以,如果你刚刚释放了 first_matrix,像这样:

free(first_matrix);

您只会从堆上自己的内容中释放 first_matrix (而不是每个元素中的那个)

于 2013-03-14T10:46:09.413 回答