0
guys :)我有一個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;
}
你的意思是不正常工作?你得到一個錯誤?錯誤的結果?還有別的嗎? – Reti43
使用'c'循環'''''',但是您使用'l'創建它。休息一下...... ;-) – alk
它也可以幫助清理你的代碼,正確縮進它:減少噪音,提高認識... – alk