C++容器巢狀實現動態二維陣列

老司機的詩和遠方發表於2020-04-06

實現程式碼

#include<stdio.h>
#include <iostream>
#include <vector>

using namespace std;

int main()
{
    int row, column;
    cin >> row >> column;
    vector<vector<int> > a(row,    vector<int>(column));
    //row決定最裡面層容器大小,vector<int>(column)決定外層容器的型別和大小

    for (int j = 0; j < row; j++)
       for (int k = 0; k< column; k++)
            a[j][k] = rand() % 100;

    for (int j = 0; j < row; j++)
    {
        cout << endl;
        for (int k = 0; k< column; k++)
        {
            a[j][k] = rand() % 100;
            cout << a[j][k] << "     ";
        }
    }

    while (1)
    {

    }
    return 0;
}

方法二

利用vector的成員函式resize,來制定大小

#include<stdio.h>
#include <iostream>
#include <vector>

using namespace std;



int main()
{
    int row, column;
    cin >> row ;

    vector<vector<int> > a(row);//row決定最裡面層容器大小,vector<int>(column)決定外層容器的型別和大小
    for (int k = 0; k < row; k++)
        a[k].resize(row);//row*row矩陣
    //使用空間
    for (int j = 0; j < row; j++)
        for (int k = 0; k< row; k++)
            a[j][k] = rand() % 100;

    for (int j = 0; j < row; j++)
    {
        cout << endl;
        for (int k = 0; k< row; k++)
        {
            a[j][k] = rand() % 100;
            cout << a[j][k] << "     ";
        }
    }
    while (1)
    {

    }
    return 0;
}

測試結果

這裡寫圖片描述

總結

1、動態陣列的使用有時候對於一些程式實現更加靈活的介面非常有必要!
2、vector想要使用陣列下標[]來索引裡面的元素的時候,vector定義的時候需要給了具體的大小(當然裡面的引數可以是變數)

相關文章