int **p;
p = new int*[10];    //注意,int*[10]表示一个有10个元素的指针数组
for (int i = 0; i < 10; ++i)
    p[i] = new int[5];

二、使用迭代器对二维数组遍历

void reverse_with_iterator(vector<vector<int>> vec)
    if (vec.empty())
        cout << "The vector is empty!" << endl;
        return;
    vector<int>::iterator it;
    vector<vector<int>>::iterator iter;
    vector<int> vec_tmp;
    cout << "Use iterator : " << endl;
    for(iter = vec.begin(); iter != vec.end(); iter++)
        vec_tmp = *iter;
        for(it = vec_tmp.begin(); it != vec_tmp.end(); it++)
            cout << *it << " ";
        cout << endl;

三、练习题

867. 转置矩阵

给你一个二维整数数组 matrix, 返回 matrix 的 转置矩阵 。

矩阵的 转置 是指将矩阵的主对角线翻转,交换矩阵的行索引与列索引。

class Solution {
public:
    vector<vector<int>> transpose(vector<vector<int>>& matrix) {
        int row=matrix.size();      //表示原矩阵有row行
        int column=matrix[0].size();  //表示原矩阵有column列
        vector<vector<int>> vec(column);
        for(int i=0;i<column;i++)
            vec[i].resize(row);
        //等价于vector<vector<int>> vec(column,vector<int>(row,0));
        for(int i=0;i<row;i++)
            for(int j=0;j<column;j++)
                vec[j][i]=matrix[i][j];
        return vec;