实现代码

#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定义的时候需要给了具体的大小(当然里面的参数可以是变量)

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐