在C中使用realloc()函数增加2D数组

时间:2017-03-12 10:54:38

标签: c arrays matrix realloc

我有以下代码,必须调整2D数组矩阵的列:

#include <stdio.h> 
#include <stdlib.h>
int main(int argc, char * argv[]){

int n = 3;
int m = 4;
int * * mas = malloc(n * sizeof( * mas));

for (int i = 1; i < n + 1; i++) {
  mas[i] = malloc(m * sizeof( * (mas[i])));
}
for (int i = 1; i < n + 1; i++) {
  for (int j = 0; j < m; j++) {
    mas[i][j] = i + 1;
    printf("%d ", mas[i][j]);
  }
  printf("\n");
}
printf("\n");

当我调整矩阵列(但保留相同大小的行)时,它完成了一个循环:

for (int i = 1; i < n + 1; i++) {
  int * tmp = realloc(mas[i], (m + 1) * sizeof( * mas[i]));
  if (tmp) {
    mas[i] = tmp;
  }
}

mas[1][4] = 100;
mas[2][4] = 200;
mas[3][4] = 300;

for (int i = 1; i < n + 1; i++) {
  for (int j = 0; j < m + 1; j++) {
    printf("%d ", mas[i][j]);
  }
  printf("\n");
}
for(int i = 1; i< n+1; i++){
    free(mas[i]);
}
free(mas);
system("pause");
return 0;
}
  I have:
  2 2 2 2
  3 3 3 3
  4 4 4 4

打印完myprg.exe后

但是当我使用简单的矢量进行调整时,它已经完成了!

#include <stdio.h> 
#include <stdlib.h>

int main(int argc, char * argv[]) {
int n = 3;
int m = 4;
int* mas = malloc(n*sizeof(mas));

for(int i = 1; i < n+1; i++){
    mas[i] = 0;
}
for(int i = 1; i < n+1; i++){
    printf("%d\n", mas[i]);
}
mas = realloc(mas, (n+2)*sizeof(*mas));
for(int i = 1; i < n+3; i++){
    mas[i] = 0;
}
for(int i = 1; i < n+3; i++){
     printf("%d\n", mas[i]);
}
free(mas);
system("pause");
return 0;
}

我认为它是2D阵列指针的东西,但我不明白到底是什么:(

1 个答案:

答案 0 :(得分:0)

在代码中将for (int i = 1; i < n + 1; i++)替换为for (int i = 0; i < n; i++)。数组索引从0n-1而不是1n

同样,改变

mas[1][4] = 100;
mas[2][4] = 200;
mas[3][4] = 300;

mas[0][4] = 100;
mas[1][4] = 200;
mas[2][4] = 300;

出于同样的原因。

最好还检查这些malloc的返回值,看看它们是否成功。此外,如果realloc失败且tmpNULL,您应该采取适当的措施。