将1D数组转换为2D矢量c ++

时间:2012-06-27 10:16:52

标签: c++ visual-c++

有人可以帮我编写一个将ID数组转换为2D矢量的逻辑。

类似

int array[] = {1, 4, 5, 7, 9, 3}; // dynamic array
vector <vector int> ex;

我现在如何将值放在数组中的ex ..以便它形成3个值的2个向量?

我已经搜索过没有用的帮助,并自己尝试了如下:

for(int i=0; i<2; i++)
{   
        rowTemp_ex.assign(array, array+3));
 ex.push_back(rowTemp_ex);
 rowTemp_ex.erase(rowTemp_ex.begin() , rowTemp_ex.end());
}

3 个答案:

答案 0 :(得分:1)

首先,计算将有多少行向量。如果每个元素都有三个元素,则总数是数组的大小除以3。

template <typename T, std::size_t N>
std::size_t size(T(&)[N]) { return N; }

int number_of_rows = size(array) / 3;

现在创建一个具有该行数的向量,每个行向量包含三个元素:

std::vector<std::vector<int> > v(number_of_rows, std::vector<int>(3));

然后遍历原始数组并使用整数除法和余数运算填充结果的每个单元格:

for(int i = 0; i < size(array); ++i) {
    v[i / 3][i % 3] = array[i];
}

答案 1 :(得分:1)

你在正确的轨道上,但在你的for循环中出错:

rowTemp_ex.assign(array, array+3));

这将在每次迭代时分配数组的相同部分。您需要将行(3)的大小乘以i:

rowTemp_ex.assign(array + i * 3, array + (i * 3) + 3));

i = 0:      0*3                  0*3+3
i = 1:                            1*3                   1*3 + 3
array:    [  0  ][  1  ][   2  ][   3  ][  4   ][  5  ] [one past the end]

vector::erase的调用是多余的,vector::assign在下一次迭代中无论如何都会丢弃以前的内容。

这里有一些更通用的东西,它也会处理可能的奇数元素(未经测试):

const size_t arr_size = N;
const size_t n_cols = M;
const size_t n_rows = arr_size / n_cols;
const size_t n_odd = arr_size % n_cols;

int arr[arr_size] = { .... };

int* begin = arr;
int* end = arr + (n_rows * n_cols);

while( begin != end ) {
    ex.push_back(std::vector<int>(begin, begin + n_cols));
    begin += n_cols;
}

if (n_odd)
    ex.push_back(std::vector<int>(begin, begin + n_odd));

答案 2 :(得分:0)

假设您希望总是三个大小为2的向量,并且2D向量在C阵列中成对对齐,请执行以下操作:

int array[] = {1, 4, 5, 7, 9, 3}; // dynamic array
vector<vector<int> > ex;

for(int i = 0; i < 3; ++i)
{
    vector<int> tmp;
    tmp.push_back(array[2*i]);
    tmp.push_back(array[2*i+1]);
    ex.push_back(tmp);
}