在c++中,有的时候会遇到变长的数组(不管是一维的还是二维的),这个时候就需要用到动态数组了,并且要用new和delete两个操作符,这俩操作符一般成对使用。
一维的动态数组
#include<iostream>
using namespace std;
int main()
{
int n; //输入数组长度
cin >> n;
int* p= new int[n]; /*创建了一个长度为n的动态数组,并且返回这个数组的首地址给p,p就指向了这个动态数组,可以通过指针p
来操作数组,因为创建的动态数组并没有名字,只返回了首地址给p,所以可以把p看作是这个动态数组的名字 */
for (int i = 0; i < n; i++)
{
cin >> p[i];
}
for (int i = 0; i < n-1; i++)
{
cout << p[i] << " ";
}
cout << p[n-1] << endl;
cout << p; //输出指针p的地址
delete[]p; //释放这个一维的动态数组,而不是释放指针p。用完以后要记得释放掉
system("pause");
return 0;
}
用完了以后,在14行释放掉了这个动态数组,而不是释放的指针p(以便接下来还能使用),接着又输出了指针p的地址。如果你释放掉了指针p,delete p; 那么接下来就
不能再使用用指针p了,因为p所占的内存空间已经释放了,再用的话就会出错。比如在第14行后加上 delete p;然后再执行下一条语句 cout<<p; 来输出p的地址就会报错
二维的动态数组
#include<iostream>
using namespace std;
int main()
{
int m, n; //输入数组大小
cout << "请输入二维数组行数:" << endl;
cin >> m;
int* column= new int[m]; //column用来记录每行元素的个数,因为每行元素的个数可能不同,如果都相同的话就不需要了
int** p = new int* [m]; //声明一个二级指针
//创建了一个有m行的的二维动态数组;可以看成数组p[m]中每个元素都是指针,用来指向一个数组
cout << "请输入各行元素个数:" << endl;
for (int i = 0; i < m; i++)
{
cout << "第" << i+1 << "行的元素个数为:" << endl;
cin >> n;
column[i] = n;
p[i] = new int[n]; //确定每行元素的个数,p[i](一级指针)为每行元素的首地址
}
for (int i = 0; i < m; i++) //输入每行元素的值
{
cout << "第" << i + 1 << "行的元素分别为:" << endl;
for (int j = 0; j < column[i]; j++)
{
cin >> p[i][j];
}
}
cout << "---------输出每行元素-----------\n";
for (int i = 0; i < m; i++) //输出每行元素
{
for (int j = 0; j < column[i]; j++)
cout << p[i][j] << " ";
cout << endl;
}
for (int i = 0; i < m; i++) //用完释放掉每行(释放二级指针)
{
delete[]p[i];
}
cout << "指针p的地址:" << p; //输出指针p的地址
delete[]p; //释放掉每行后,再释放这个二维数组(释放一级指针)
return 0;
}
运行结果如下: