1. 程式人生 > 其它 >vector 建立二維陣列

vector 建立二維陣列

方法一:

#include <iostream>
#include <vector>
using namespace std;

void test01() {
//建立一個外層容器
vector<vector<int>>v;
//建立一些內層容器,並賦值
vector<int>v1(10,1);
vector<int>v2(10,2);
vector<int>v3(10,3);
//將內層小容器插入到大容器之中,類似於二維陣列。
v.push_back(v1);
v.push_back(v2);
v.push_back(v3);

}

遍歷訪問:

1.得到的行列大小,利用類似於陣列訪問

void reverse_with_index(vector<vector<int>> vec)
{
if (vec.empty())
{
cout << "The vector is empty!" << endl;
return;
}

int i,j;
cout << "Use index : " << endl;
for (i = 0; i < vec.size(); i++)
{
for(j = 0; j < vec[0].size(); j++)
cout 
<< vec[i][j] << " "; cout << endl; } } /*———————————————— 版權宣告:本文為CSDN博主「雪倫_」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處連結及本宣告。 原文連結:https://blog.csdn.net/a819825294/article/details/52088732 */

2.利用迭代器開始遍歷

for (vector<vector<int>>::iterator it = v.begin(); it != v.end(); it++) {
for (vector<int
>::iterator it1 = (*it).begin(); it1 != (*it).end(); it1++) { cout << *it1 << " "; } cout << endl; }

方法二:一維擴充法

#include <iostream>
#include <vector> //如果想用vector必須包含對應標頭檔案
using namespace std;

int main()
{
vector<vector<int> > vec(m); //這裡m就是相當於二維陣列的行數,必須寫,不然報錯

//這裡建立一個m*n的二維vector
for(int i = 0;i<m;i++)
{//這裡是給內層vector定義大小。預設是0,這裡n是個數,不是值

vec[i].resize(n); //利用resize進行擴充
}


//賦值,我嘗試了一下vec.[i].push_back(10)來為其賦值,不過失敗了,可能不可以這樣做。
for (int i = 0; i < 3; i++) {
for (int j = 0; j < 5; j++) {
vec[i][j] = j + 100;
}
}

system("pause");
return 0;
}



————————————————
版權宣告:本文為CSDN博主「why you learn hard?」的原創文章,遵循CC 4.0 BY-SA版權協議,轉載請附上原文出處連結及本宣告。
原文連結:https://blog.csdn.net/hacker_zrq/article/details/112162049