歡迎來到Linux教程網
Linux教程網
Linux教程網
Linux教程網
Linux教程網 >> Linux編程 >> Linux編程 >> C++中動態申請二維數組

C++中動態申請二維數組

日期:2017/3/1 9:38:01   编辑:Linux編程

這裡主要介紹C++中動態申請二維數組的兩種方式,直接給出代碼,很容易明白,簡單的作為一個筆記。

#include <iostream>
#include <iomanip> // 輸入輸出操縱
#include <vector>
using namespace std;


// 法一:new 方式申請
void dynamicArray()
{
int rows, cols;
cin >> rows >> cols;
int **element = new int* [rows]; // 申請二維動態數組
int i;
for (i = 0; i < rows; i++)
element[i] = new int[cols];

int j;
for(i = 0; i < rows; i++) // 初始化
{
for (j = 0; j < cols; j++)
{
cin >> element[i][j];
}
}
for (i = 0; i < rows; i++)
{
for(j = 0; j < cols; j++)
{
cout << setw(4) << element[i][j]; // 每個輸出占四個字符,前面以空格填充
//cout << setfill('*') << element[i][j]; // 空格以*填充
}
cout << endl;
}

for(i = 0; i < cols; i++) // 釋放動態數組
{
delete []element[i];
}
delete []element;

}

// 法二:vector 方式 沒用new無需釋放
void dynamicArray2()
{
int rows, cols;
cin >> rows >> cols;
vector<vector<int>> element(rows, vector<int>(cols)); // 用vector申請二維動態數組
int i,j;
for(i = 0; i < rows; i++) // 初始化
{
for (j = 0; j < cols; j++)
{
cin >> element[i][j];
}
}
for (i = 0; i < rows; i++)
{
for(j = 0; j < cols; j++)
{
cout << setw(4) << element[i][j]; // 每個輸出占四個字符,前面以空格填充
//cout << setfill('*') << element[i][j]; // 空格以*填充
}
cout << endl;
}

}

cout << "d5 = " << fixed<<setprecision(2)<< d5 << endl; 保留小數點兩位

C++ 設計新思維》 下載見 http://www.linuxidc.com/Linux/2014-07/104850.htm

C++ Primer Plus 第6版 中文版 清晰有書簽PDF+源代碼 http://www.linuxidc.com/Linux/2014-05/101227.htm

讀C++ Primer 之構造函數陷阱 http://www.linuxidc.com/Linux/2011-08/40176.htm

讀C++ Primer 之智能指針 http://www.linuxidc.com/Linux/2011-08/40177.htm

讀C++ Primer 之句柄類 http://www.linuxidc.com/Linux/2011-08/40175.htm

將C語言梳理一下,分布在以下10個章節中:

  1. Linux-C成長之路(一):Linux下C編程概要 http://www.linuxidc.com/Linux/2014-05/101242.htm
  2. Linux-C成長之路(二):基本數據類型 http://www.linuxidc.com/Linux/2014-05/101242p2.htm
  3. Linux-C成長之路(三):基本IO函數操作 http://www.linuxidc.com/Linux/2014-05/101242p3.htm
  4. Linux-C成長之路(四):運算符 http://www.linuxidc.com/Linux/2014-05/101242p4.htm
  5. Linux-C成長之路(五):控制流 http://www.linuxidc.com/Linux/2014-05/101242p5.htm
  6. Linux-C成長之路(六):函數要義 http://www.linuxidc.com/Linux/2014-05/101242p6.htm
  7. Linux-C成長之路(七):數組與指針 http://www.linuxidc.com/Linux/2014-05/101242p7.htm
  8. Linux-C成長之路(八):存儲類,動態內存 http://www.linuxidc.com/Linux/2014-05/101242p8.htm
  9. Linux-C成長之路(九):復合數據類型 http://www.linuxidc.com/Linux/2014-05/101242p9.htm
  10. Linux-C成長之路(十):其他高級議題

Copyright © Linux教程網 All Rights Reserved