这里主要介绍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个章节中:- Linux-C成长之路(一):Linux下C编程概要 http://www.linuxidc.com/Linux/2014-05/101242.htm
- Linux-C成长之路(二):基本数据类型 http://www.linuxidc.com/Linux/2014-05/101242p2.htm
- Linux-C成长之路(三):基本IO函数操作 http://www.linuxidc.com/Linux/2014-05/101242p3.htm
- Linux-C成长之路(四):运算符 http://www.linuxidc.com/Linux/2014-05/101242p4.htm
- Linux-C成长之路(五):控制流 http://www.linuxidc.com/Linux/2014-05/101242p5.htm
- Linux-C成长之路(六):函数要义 http://www.linuxidc.com/Linux/2014-05/101242p6.htm
- Linux-C成长之路(七):数组与指针 http://www.linuxidc.com/Linux/2014-05/101242p7.htm
- Linux-C成长之路(八):存储类,动态内存 http://www.linuxidc.com/Linux/2014-05/101242p8.htm
- Linux-C成长之路(九):复合数据类型 http://www.linuxidc.com/Linux/2014-05/101242p9.htm
- Linux-C成长之路(十):其他高级议题
本文永久更新链接地址:http://www.linuxidc.com/Linux/2014-11/108803.htm