我希望不使用矩阵vector <vector <int>>
初始化int [][]
任何帮助?感谢
答案 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值初始化向量,你可以使用任何值而不是零。