[英]How to convert a vector<vector<int>> to int** without rebuilding the array?
[英]how inialize a vector <vector <int>> with int array [][]?
我想不用矩陣int [][]
任何幫助初始化vector <vector <int>>
嗎? 謝謝
使用C ++ 11:
int matrix[5][6] = { 1,2,3 /* ... */ };
vector<vector<int>> vm;
for (auto&& row : matrix)
vm.emplace_back( begin(row), end(row) );
為了完整起見,如果你不能使用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
值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
期間不需要調整大小),第一個解決方案對於大向量可能更快。
試試這樣:
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);
//向量初始化的示例
#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值初始化向量,你可以使用任何值而不是零。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.