伙计:)我有一个2d动态数组,我需要找到每列中的最大和最小数字。我必须在我的数组中插入2个新行(最大值和最小值),但似乎我的realloc
工作不正常。请告诉我我做错了什么以及我应该如何继续。
int **in(int l,int c);
void out(int l, int c, int **a);
int max_colonne(int l, int c, int **a,int *max);
int minimal_colone(int l, int c, int **a,int *minimal);
int main()
{
int **x,*max,*minimal,l,c, i, j;
printf("nombre de lignes: ");
scanf("%d",&l);
printf("nombre de colonnes: ");
scanf("%d",&c);
x=in(l,c);
printf("La matrice cree.\n");
out(l,c,x);
for(i=0;i<c;i++){
x[i]=(int *)realloc(x, (l+2)*sizeof(int)); }
free(x) ;
free(max) ;
}
int **in(int l,int c)
{
int **t,i,j;
t=(int **)malloc(l*sizeof(int *));
for(i=0;i<l;i++)
t[i]=(int *)malloc(c*sizeof(int));
for(i=0;i<l;i++)
for(j=0;j<c;j++)
{ printf("el[%d][%d]:",i,j);
scanf("%d",(t[i]+j));
}
return t;
}
void out(int l, int c, int **a)
{
int i,j;
for(i=0;i<l;i++)
{ for(j=0;j<c;j++)
printf("%3d",*(a[i]+j));
printf("\n");
}
}
int max_colonne(int l, int c, int **a,int *max)
{
int i,j;
for(j=0;j<c;j++,max++)
{ *max=*a[j];
for(i=0;i<l;i++)
if(*(a[j]+i) > *max) *max=*(a[j]+i);
} return *max;
}
int minimal_colone(int l, int c, int **a,int *minimal)
{
int i,j;
for(j=0;j<c;j++,minimal++)
{ *minimal=*(a[0]+j);
for(i=0;i<c;i++)
if(*(a[i]+j) < *minimal) *minimal=*(a[i]+j);
} return *minimal;
}
答案 0 :(得分:1)
您的realloc
无效,因为它错了,而不是
x[i]=(int *)realloc(x, (l+2)*sizeof(int));
应该是
x[i] = realloc(x[i], (l + 2) * sizeof(int));
而且,您也不需要转发int *
。
您应始终检查malloc
/ realloc
/ calloc
个函数的返回值,如果它们返回NULL
失败,请安全使用realloc
你应该使用一个临时变量,以防止丢失原始指针,因为如果你这样做
x[i] = realloc(x[i], newSize);
和realloc
返回NULL
然后您丢失了对原始指针x[i]
的重新引用,因此我建议
void *tmp;
tmp = realloc(x[i], newSize);
if (tmp == NULL)
handleMallocFailureErrorProbablyRetryOrExitTheProgram();
x[0] = tmp;
例如,您可以free(x[i])
中的handleMallocFailureErrorProbablyRetryOrExitTheProgram()
。