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;
三、练习题
给你一个二维整数数组 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;