具有可变大小行的C ++ 2维数组

时间:2012-07-18 06:22:04

标签: c++ arrays vector multidimensional-array jagged-arrays

如何创建一个二维数组,比如说,arr[][]有5行,每行中的列数可变?

可能arr[5][] 第一行arr[0][]有4列

第2行arr[1][]有5列,依此类推?

我不介意STL矢量解决方案,但我还不太了解矢量。

4 个答案:

答案 0 :(得分:16)

使用C ++ 11,您可以使用向量轻松完成(为了便于阅读而添加换行符):

std::vector< std::vector <int > > arr = {
{1,2,3},
{4,5},
{6,7,8,9,0}
};

如果您没有C ++ 11编译器,它的工作方式完全相同,但您无法轻松初始化它们。您可以单独设置元素:

std::vector< std::vector <int > > arr;//vector of vectors. Think of each element as of a "row"
std::vector<int> sub;//a temporary "row"
sub.push_back(1);
sub.push_back(2);
arr.push_back(sub);//Adding a "row" to the vector
sub.clear();//Making another one
sub.push_back(1);
sub.push_back(12);
sub.push_back(54);
arr.push_back(sub);//Adding another "row" to the vector

或者您可以使用普通数组初始化每个“行”:

std::vector< std::vector <int > > arr;
static const int arr[] = {1,2,3,4};//A "row" as an ordinary array
vector<int> vec (arr, arr + sizeof(arr) / sizeof(arr[0]) ); //Setting a "Row" as a vector
arr.push_back(vec);//Adding the "row" to the vector of vectors. 

用普通数组做你想做的事情是不可能的,因为当你创建一个array[X][Y]时,它自动地是一个X*Y矩阵。但是,您可以使用指针数组:

int * array[3];
//also possible: int ** array =  new int*[3]; but don't forget to delete it afterwards.
int sub1[3] = {1,2,3};
int sub2[2] = {1,2};
int sub3[4] = {1,2,3,4};
array[0] = sub1;
array[1] = sub2;
array[2] = sub3;

并使用array[X][Y]访问元素。但是,矢量解决方案总体上要好得多。

答案 1 :(得分:7)

你可以这样做(假设有一个int元素数组):

int** arr = new int*[5];
for(size_t i = 0; i < 5; ++i)
{
    arr[i] = new int[4];
}

这为你提供了一个5乘4的二维动态分配数组。然后可以像这样使用它:arr[i][j] = 15;

使用完阵列后,不要忘记取消分配内存:

for(size_t i = 0; i < 5; ++i)
{
    delete[] arr[i];
}
delete[] arr;

但我建议使用std::vector。您可以查看其他答案以供参考。

答案 2 :(得分:0)

一种用于不同行大小的方法

#include <iostream>
#include <string>
int main()
{
  int test1[]={1,2,3};
  int test2[]={4,5};

  int *test[]={test1,test2};

  std::cout << test[0][1];//2
  std::cout << test[1][1];//5
}

答案 3 :(得分:-1)

因此,2D数组是std::vector<std::vector<T>>,其中T是类型。另外,mb std::array<std::vector<int>, 5>。或者编写自己的数组类。