C++ new二维数组

C++编程语言中有一种叫做new的二维数组,它的应用方式比较灵活,可以有多种方法来帮助我们实现一些特定功能。在这里我们将会总结几种C++二维数组new的应用方式,来进行逐一的点评。

C++二维数组new应用方式一:

  1. A (*ga)[n] = new A[m][n];   
  2. ...   
  3. delete []ga;  

缺点:n必须是已知

优点:调用直观,连续储存,程序简洁(经过测试,析构函数能正确调用)

C++二维数组new应用方式二:

  1. A** ga = new A*[m];   
  2. for(int i = 0; i < m; i++)   
  3. ga[i] = new A[n];   
  4. ...   
  5. for(int i = 0; i < m; i++)   
  6. delete []ga[i];   
  7. delete []ga;  

缺点:非连续储存,程序烦琐,ga为A**类型

优点:调用直观,n可以不是已知

C++二维数组new应用方式三:

  1. A* ga = new A[m*n];   
  2. ...   
  3. delete []ga;  

缺点:调用不够直观

优点:连续储存,n可以不是已知

C++二维数组new应用方式四:

  1. vector > ga;   
  2. ga.resize(m); //这三行可用可不用   
  3. for(int i = 1; i < n; i++) //   
  4. ga[i].resize(n); //   
  5. ...  

缺点:非连续储存,调试不够方便,编译速度下降,程序膨胀(实际速度差别不大)

优点:调用直观,自动析构与释放内存,可以调用stl相关函数,动态增长

C++二维数组new应用方式五:

  1. vector ga;   
  2. ga.resize(m*n);  

方法3,4的结合

C++二维数组new应用方式六:

2的改进版

  1. A** ga = new A*[m];   
  2. ga[0] = new A[m*n];   
  3. for(int i = 1; i < m; i++)   
  4. ga[i] = ga[i-1]+n;  

优点:连续存储,n可以不是已知,析构方便,猜想只需delete [] ga;

总结:以上就是各种各样的C++通过new的方式创建二维数组,可以发展很难管理且较为麻烦,我们难免可能会遇到忘记delete或者越界的情况。其实使用vector来动态管理更加方便且创建局部变量不用操心delete,适合各种类型,例如vector <vector <int>> vec,所以更推荐。

 

### 创建和初始化二维数组C++中,可以使用多种方式来创建和初始化二维数组。以下是几种常见的方式: #### 使用静态数组 当大小已知且固定时,可以直接定义并初始化一个二维数组。 ```cpp #include <iostream> int main() { // 定义并初始化一个3x3的二维数组 int matrix[3][3] = { {1, 2, 3}, {4, 5, 6}, {7, 8, 9} }; for (size_t i = 0; i < 3; ++i) { for (size_t j = 0; j < 3; ++j) { std::cout << matrix[i][j] << " "; } std::cout << "\n"; } return 0; } ``` 此方法适用于编译时常量尺寸的情况[^1]。 #### 动态分配内存 对于运行时期望改变维度的情形,则需借助`new`运算符动态申请空间,并通过指针访问元素。 ```cpp #include <iostream> int main(){ const size_t rows = 3; const size_t cols = 3; // 动态分配二维数组 int **matrix = new int*[rows]; for(size_t i=0 ; i<rows ; ++i){ matrix[i]=new int[cols]{}; } // 初始化数据 for(size_t i=0 ; i<rows ; ++i){ for(size_t j=0 ; j<cols ; ++j){ matrix[i][j]=(i*cols)+j+1; } } // 打印矩阵内容 for(size_t i=0 ; i<rows ; ++i){ for(size_t j=0 ; j<cols ; ++j){ std::cout<<matrix[i][j]<<" "; } std::cout<<"\n"; } // 清理资源 for(size_t i=0 ; i<rows ; ++i){ delete[] matrix[i]; } delete[] matrix; return 0; } ``` 这种方法虽然灵活但是需要注意手动管理释放掉不再使用的堆上分配的空间以防止泄漏问题的发生[^2]。 #### 利用标准库容器 `std::vector` 为了简化操作以及自动处理内存管理和边界检查等问题,推荐采用STL中的向量类模板实现多维结构体表示法。 ```cpp #include <iostream> #include <vector> int main(){ constexpr size_t rows{3}, cols{3}; // 声明并初始化一个包含三个整数向量的标准库容器 std::vector<std::vector<int>> matrix(rows, std::vector<int>(cols)); // 给定初始值填充整个表格 int value = 1; for(auto& row : matrix){ for(auto& elem : row){ elem=value++; } } // 输出最终结果 for(const auto& row : matrix){ for(int val : row){ std::cout<<val<<" "; } std::cout<<"\n"; } return 0; } ``` 这种方式不仅安全而且易于维护,在现代C++编程实践中被广泛接受和支持[^3]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值