C++ vector二维数组用法_C++ vector嵌套初始化与遍历技巧

使用vector可灵活实现二维数组,声明方式为vector,支持空初始化、指定行列、自定义值和列表初始化;遍历推荐范围for循环,也可用迭代器或下标访问;注意每行长度可变,插入用push_back,清空用clear,传参建议使用常引用以提升效率。

在C++中,使用vector实现二维数组是一种常见且灵活的方式。相比传统数组,vector能动态管理内存,避免越界风险,尤其适合处理不确定大小的二维数据结构。通过嵌套vector(即vector>),我们可以轻松构建和操作二维结构。

vector二维数组的声明与初始化

定义一个二维vector,本质是创建一个vector,其元素类型也是vector。例如,存储整数的二维容器可声明为:

vector> matrix;

初始化方式有多种,可根据需要选择:

  • 空初始化:先声明空容器,后续动态添加行和列
  • vector> grid;
  • 指定行列大小:初始化为m行n列,所有元素默认为0
  • vector> mat(3, vector(4)); // 3行4列
  • 自定义初始值:设定特定初始值,如-1或99
  • vector> data(2, vector(3, -1)); // 值全为-1
  • 列表初始化:直接赋初值,适合已知数据的小型矩阵
  • vector> table = {{1, 2}, {3, 4}, {5, 6}};

二维vector的遍历方法

遍历二维vector有多种方式,根据场景选择合适的方法可以提高代码清晰度和效率。

  • 基于范围的for循环(推荐):简洁直观,适合只读或引用访问
  • for (const auto& row : matrix) {
      for (const auto& elem : row) {
        cout   }
      cout }
  • 迭代器遍历:灵活性高,支持修改和反向遍历
  • for (auto it = matrix.begin(); it != matrix.end(); ++it) {
      for (auto jt = it->begin(); jt != it->end(); ++jt) {
        cout   }
    }
  • 下标访问:适合需要索引信息的场景,如对角线操作
  • for (int i = 0; i   for (int j = 0; j     cout   }
    }

常见操作与注意事项

使用vector嵌套时,注意以下几点可避免常见错误:

  • 每行的列数可以不同,形成“不规则矩阵”,遍历时应使用matrix[i].size()而非固定值
  • 插入新行:matrix.push_back({7, 8, 9});
  • 清空全部内容:matrix.clear();
  • 检查是否为空:if (matrix.empty() || matrix[0].empty())
  • 传参给函数时,建议使用常引用避免拷贝开销:
    void print(const vector>& mat)

基本上就这些。掌握vector嵌套的初始化和遍历方式,能让你在处理矩阵、图邻接表或动态表格时更加得心应手。关键是理解每一层vector的含义,并根据实际需求选择合适的操作方式。