动态分配数组

时间:2017-08-21 20:30:31

标签: c++ dynamic dynamic-allocation

我想声明一个没有初始大小的2D数组。它不断给我一个错误:

  

错误C2078:初始化太多。

我已经尝试动态分配我的数组,但到目前为止我还不熟悉动态分配。我的问题是,如果有可能的方法来声明没有初始大小的数组,如果是这样,最有效的方法是什么?

2 个答案:

答案 0 :(得分:1)

  

我的问题是,如果有可能的方法来声明没有初始大小的数组,如果是这样,最有效的方法是什么?

当然,你可以提供一个向量矢量来表示一个二维数组(假设是整数值):

 std::vector<std::vector<int>> my2DArray;

嗯,关于效率可能是性能和内存碎片,最好将内部保留的1D向量包含在允许2D坐标访问的接口中。

这需要您知道并指定尺寸限制。

因此,如果你真的想要保留一个没有初始大小的 ,那么上面提到的向量矢量就是你的选择。

答案 1 :(得分:1)

我使用指针,新函数和删除函数编写了一个简单的程序。您可以为其添加更多功能。

#include <iostream>
using namespace std;
int main()
{
    int size;
    cout << "Input size of 2D array : ";
    cin >> size;

    int *ptr; // Declare Pointer

    ptr = new int[size*size]; // Allocate memory of all elements in 2D array

    for (int i = 0; i < size*size; i++) {
        *(ptr + i) = 0; // Initialize every element to 0
    }

    cout << "Printing the 2D Array" << endl << endl;

    int iterSize = 0;

    for (int i = 0; i < size; i++) {
        for (int j = 0; j < size; j++) {
            cout << *(ptr + iterSize) << " ";
        }
        cout << endl;
    }

    delete [] ptr; // ptr memory is released

    return 0;
}

这是将所有元素初始化为0的输出:

Initialized all elements to 0