C++ 动态开辟二维数组的的方法
近日写到一个程序,用到了要动态开辟二维数组,一想,自己就会两种。一者:用new在堆上开辟;二者:用vector开辟。技巧没有多少,但是确实是折腾了我半天!首先,大家去网上搜一下,动态开辟二维数组的文章特别多,再加上我这篇就更多了,我本不想写这篇博文的。但看了网上各位“大虾”“大牛”写的,觉得还是有必要写一下!给各位讲清楚点,以防被网上质量残次不齐的文章误导了。
写文章者,都是学习总结之用!为了是自己的快活,也为了别人的参考方便。
那我想在就讲讲我经常用到的两种方法;
一:C++ new 法
首先贴出我写的一个小小的代码吧!以供大家评论!代码都经本人在VC++ 6.0上编译运行过,无错!至于有高手再能找出bug,那就给我提出来吧,我也进步,进步!
#include <iostream>
#include <iomanip>
using namespace std;
void main()
{
int row, col;
int **element = NULL;
cin>>row
>>col;
//动态开辟数组
element = new int *[row];
for (int i = 0; i < row; i++)
{
element[i] = new int[col];
}
//输入数组
cout<<endl;
for (i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
cin>>element[i][j];
}
}
//输出数组
cout<<endl;
for (i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
cout<<setw(5)<<element[i][j];
}
cout<<endl;
}
}
关键之处我用红笔标绘出来了!大家肯定一看就懂了!
但是,有时对于新手来说,确实很懵懂的。开辟一维数组是何等简单,但是二维数组还是用开辟一维数组的思想!
程序不足之处是没有销毁开辟的空间!那大家在看看销毁的代码吧!
//销毁空间
for (i = 0; i < row; i++)
{
delete []element[i];
element[i] = NULL;
}
delete []element;
element = NULL;
这是销毁开辟的空间的代码!
用new在堆上开辟的空间,必须要用delete释放了,不然要出现内存泄露了!
二:vector法
学习C++,就不得不学习STL了。用vector开辟二维数组也不失为一个好办法!
首先看一段代码!
#include <iostream>
#include <vector>
#include <iomanip>
using namespace std;
void main()
{
int row, col;
cout<<"请输入行列值:";
cin>>row
>>col;
vector<vector<int> > test(row, vector<int>(col)); //声明一个二维数组,注意这里的空格不能少
//初始化,其实不初始化也是可以的,vector默认是0
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
test[i][j] = 0;
}
}
cout<<endl;
//输出值
for (i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
cout<<setw(5)<<test[i][j];
}
cout<<endl;
}
//输出行列值
cout<<"行:"<<test.size()<<endl;
cout<<"列:"<<test[1].size()<<endl;
}
编译时两次调用vector的构造函数对象test,第一次调用构造一个无名的含有col个0的vector<int>对象.
第二次调用构造函数,以这个无名向量为初始值初始化它的row个元素!
文章写到这里到此为止,希望对这里还有迷茫的人有所帮助,也希望你们提出意见,对我的代码书写规范之处提出宝贵的意见!大家互相学习!