C++的二维vector和C的二维数组学习

C++的二维vector和C的二维数组学习

参考了http://blog.csdn.net/zhuqinglu/article/details/1805050

可通过下列代码直接创建m*n的二维vector
vector<vector <int> > ivec(m ,vector<int>(n));    //m*n的二维vector

动态创建m*n的二维vector
方法一:
vector<vector <int> > ivec;
ivec.resize(m);
for(int i=0;i<m;i++) ivec[i].resize(n);

方法二:
vector<vector <int> > ivec;
ivec.resize(m,vector<int>(n));

动态创建二维数组a[m][n]
C语言版:

创建代码:

#include<malloc.h>
int **a=(int **)malloc(m*sizeof(int *));
for(int i=0;i<m;i++)
a[i]=(int *)malloc(n*sizeof(int));

释放代码:

for (i=0;i<m;i++)
{
     free(data[i]);
}              
free(data);


C++版:
创建代码:

int **a=new int*[m];
for(int i=0;i<m;i++) a[i]=new int[n];

释放代码:

for(int i = 0; i != m; i++)
{
    delete[] p[i];
}
delete[] p;

初始化二维数组:

int a[2][2] = {{1,2},
                  {3,4}};

初始化二维vector:

如果全初始化为0:

vector<vector <int> > ivec(m ,vector<int>(n,0));    //m*n的二维vector,所有元素为0

也可以用

        vector<vector<int>> A;
        A.resize(m, vector<int>(n, 0));

注意:上例中n固定。但二维vector的第二维的size()并不一定要是常数,如下例中的三个vector组成的二维vector,其大小分别为1,2,3。这一点跟C的二维数组不一样。

vector<vector<int> > vecSet;
for(int i = 1; i <= 3; i++)
    vecSet.push_back(vector<int>(i,0));

如果初始化为不同值:

vector<vector<int> > a {{1,2}, {3,4}};

注意与上面的C的二维数组区别,这里a的后面加不加'='号都可以

如果C++的class里面定义了vector,可以在class的constructor里面初始化,比如:

class Myclass {
public: 
    Myclass(int m_size): v1(my_size,0), v2(m_size, 0){}
    ...
private:
    vector<int> v1, v2; 
}

如果想遍历二维vector(按vector一个一个来),可以用C++ 11的auto,比如

#include <iostream>
#include <vector>

using namespace std;

int main() {

  vector<vector<int> > v = {{1,2}, {3,4}};
  for (const auto& inner : v) {
      for (const auto& item : inner) {
          cout << item << " ";
      }
  }
  cout << endl;

  return 0;
}

定义一个二维数组,第一维有26个,但第二维不定。

 vector<vector<int>> vecs(26, vector<int>());

三维vector怎么定义呢? 一个例子如下

 vector<vector<vector<bool> > > dp (n, vector<vector<bool> >(n, vector<bool>(n + 1, false)));

另一个三维vector的初始化例子:
vector<vector<vector<int>>> dp(len + 1, vector<vector<int>>(k + 1, vector<int>(target + 1, 0)));

二维vector的初始化如下:
假设已经有vector<vector<bool>> board;
vector<vector<bool> > mask(board.size(), vector<bool>(board[0].size(), true));
 

下面是一些关于C/C++ 二维数组初始化的资料,引用自
C语言二维数组的定义、初始化、赋值

二维数组的初始化(赋值)

二维数组的初始化可以按行分段赋值,也可按行连续赋值。

例如,对于数组 a[5][3],按行分段赋值应该写作:

int a[5][3]={ {80,75,92}, {61,65,71}, {59,63,70}, {85,87,90}, {76,77,85} };

按行连续赋值应该写作:

int a[5][3]={80, 75, 92, 61, 65, 71, 59, 63, 70, 85, 87, 90, 76, 77, 85};

这两种赋初值的结果是完全相同的。
对于二维数组的初始化还要注意以下几点:

1) 可以只对部分元素赋值,未赋值的元素自动取“零”值。例如:

int a[3][3] = {{1}, {2}, {3}};

是对每一行的第一列元素赋值,未赋值的元素的值为 0。赋值后各元素的值为:
1  0  0
2  0  0
3  0  0

再如:

int a[3][3] = {{0,1}, {0,0,2}, {3}};

赋值后各元素的值为:
0  1  0
0  0  2
3  0  0

2) 如果对全部元素赋值,那么第一维的长度可以不给出。例如:

int a[3][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};

可以写为:

int a[][3] = {1, 2, 3, 4, 5, 6, 7, 8, 9};

3) 二维数组可以看作是由一维数组嵌套而成的;如果一个数组的每个元素又是一个数组,那么它就是二维数组。当然,前提是各个元素的类型必须相同。根据这样的分析,一个二维数组也可以分解为多个一维数组,C语言允许这种分解。

例如,二维数组a[3][4]可分解为三个一维数组,它们的数组名分别为 a[0]、a[1]、a[2]。

这三个一维数组可以直接拿来使用。这三个一维数组都有 4 个元素,比如,一维数组 a[0] 的元素为 a[0][0]、a[0][1]、a[0][2]、a[0][3]。

如果要返回一个二维空vector,可以用return vector<vector<int>>();
好像也可以用return {{}};

下面内容参考链接:https://blog.csdn.net/shizheng_Li/article/details/105862560
圆括号
vector<int> v(n):圆括号是构造函数,表示1个容量为n的vector
方括号
vector<int> v[n] :表示n个vector v ,二维数组
相当于 vector<vector<int > > v(n);二维数组

举例
vector v(10) 表示 一个容量=10的vector
vector v[10] 表示10个容量不确定的vector组成的二维数组
//

  • 2
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
要创建和遍历二维数组vector,可以使用以下方法: 1. 创建二维数组vector: - 使用vector<vector<int>>创建一个二维int类型的vector。 - 可以使用emplace_back方法将元素添加到二维vector的末尾。 - 可以使用emplace方法在指定位置插入元素。 2. 遍历二维数组vector: - 使用嵌套的迭代器循环遍历二维vector中的所有元素。 - 外层迭代器p1用于遍历一维vector,内层迭代器p2用于遍历具体的元素。 - 可以使用*p2来访问和操作每一个元素。 以下是一个示例代码,展示了创建和遍历二维数组vector的方法: ```c++ #include <iostream> #include <vector> void Print(vector<vector<int>> a) { vector<vector<int>>::iterator p1; vector<int>::iterator p2; for (p1 = a.begin(); p1 != a.end(); p1++) { for (p2 = p1->begin(); p2 != p1->end(); p2++) { cout << "[" << *p2 << "]"; } cout << endl; } cout << endl; } 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; } } int main() { int m = 10, n = 20; vector<vector<char>> map(m, vector<char>(n, '.')); map[m][n = 'Q'; vector<vector<int>> myvector = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}}; Print(myvector); reverse_with_iterator(myvector); return 0; } ``` 在上述代码中,我们首先创建了一个名为`myvector`的二维vector,并使用Print函数和reverse_with_iterator函数进行遍历和输出。然后,我们创建了一个大小为10x20的二维vector`map`,并将其中一个元素修改为'Q'。<span class="em">1</span><span class="em">2</span><span class="em">3</span><span class="em">4</span>

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值