如何初始化向量<vector <int =“”>&gt; with int array [] []?</vector>

时间:2015-04-14 05:53:03

标签: c++ arrays vector

我希望不使用矩阵vector <vector <int>>初始化int [][] 任何帮助?感谢

4 个答案:

答案 0 :(得分:5)

使用C ++ 11:

 int matrix[5][6] = { 1,2,3 /* ...  */ };

 vector<vector<int>> vm;

 for (auto&& row : matrix)
      vm.emplace_back( begin(row), end(row) );

答案 1 :(得分:1)

为了完整性,如果你不能使用C ++ 11,你可以简单地为vector<vector<int>>预先分配内存,并在双循环中将矩阵复制到其中:

#include <iostream>
#include <vector>

using namespace std;

int main()
{
    const int M = 2, N = 3;
    int matrix[M][N] = { 1, 2, 3, 4, 5, 6};

    vector<vector<int>> vm(M, std::vector<int>(N,0)); // pre-allocate memory

    for (int i = 0; i < M; ++i)
        for(int j = 0; j < N; ++j)
            vm[i][j] = matrix[i][j];
}

或者,您可以在循环中push_back rvalue vector,例如

#include <iostream>
#include <vector>

using namespace std;

int main()
{
    const int M = 2, N = 3;
    int matrix[M][N] = { 1, 2, 3, 4, 5, 6};

    vector<vector<int>> vm;

    for (int i = 0; i < M; ++i)
        vm.push_back(std::vector<int>(matrix[i] , 
            matrix[i] + sizeof(matrix[i]) / sizeof(int)));
}

由于预分配(在push_back期间无需调整大小),第一个解决方案对于大型向量可能更快。

答案 2 :(得分:0)

试试这样:

type array[2][2]=
{
   {1,0},{0,1}
};

vector<int> vec0(array[0], array[0] + sizeof(array[0]) / sizeof(type) );   
vector<int> vec1(array[1], array[1] + sizeof(array[1]) / sizeof(type) );

vector<vector<type> > vectorArr;
vectorArr.push_back(vec0);
vectorArr.push_back(vec1);

答案 3 :(得分:0)

//矢量初始化的例子

#include<bits/stdc++.h>
 using namespace std;
 int main(){
 int n = 15;
 vector<int> v(n,0);

 for(int i = 0; i < n; i++){
    cout<<v[i]<<endl;
 }
}

//这里我用0值初始化向量,你可以使用任何值而不是零。