创建具有可变大小尺寸的2D阵列

时间:2011-04-01 01:38:42

标签: c++ arrays

我希望能够创建一个二维数组,其大小与我从文件中读取的宽度和高度相同,但是当我说:

时我会遇到错误
int array[0][0]
array = new int[width][height]

3 个答案:

答案 0 :(得分:19)

你应该使用指针指针:

int** array;
array = new int*[width];
for (int i = 0;i<width;i++)
    array[i] = new int[height];

当你使用它或想要调整大小时,你应该释放分配的内存,如下所示:

for (int i = 0;i<width;i++)
    delete[] array[i];
delete[] array;

要理解并能够阅读更复杂的类型,此链接可能很有用:

http://www.unixwiz.net/techtips/reading-cdecl.html

希望这有帮助。

答案 1 :(得分:1)

尝试这种方式:

  int **array; // array is a pointer-to-pointer-to-int

    array = malloc(height * sizeof(int *));
    if(array == NULL)
        {
        fprintf(stderr, "out of memory\n");
        exit or return
        }
    for(i = 0; i < height ; i++)
        {
        array[i] = malloc(width * sizeof(int));
        if(array[i] == NULL)
            {
            fprintf(stderr, "out of memory\n");
            exit or return
            }
        }

    array = new int*[width];
    if(array == NULL)
        {
        fprintf(stderr, "out of memory\n");
        exit or return
         }
    else
    {
    for (int i = 0;i<width;i++)
        array[i] = new int[height];
    }

答案 2 :(得分:1)

如果数组是矩形的,如在您的示例中,您可以只使用一个分配:

int* array = new int[width * height];

这有效地将阵列展平为单个维度,并且速度更快。

当然,这是C ++,为什么不使用std::vector<std::vector<int> >