
本文共 935 字,大约阅读时间需要 3 分钟。
一个c++的动态二维数组的实现:(其实C语言是一样)
#include
using namespace std;
void MakeArray(int **& a); //用了引用,节约内存
void DeleteArray(int **& a);
void Show(int **& a);
int row = 0, col = 0;
int main()
{
int** buff = NULL;// 定义二维数组名(数组指针 指向数组的指针 二级指针)
int** &str = buff;// 建立引用
cout << "输入二维数组的行,列 :";
cin >> row >> col;
MakeArray(str);
Show(str);
DeleteArray(str);
system("pause");
return 0;
}
void MakeArray(int **& a)
{
// a 是个数组指针 指向数组的指针 二级指针
a = new int* [row];//分配一个指针数组,将其首地址保存在 a 中
// 遍历这个指针数组,分别指向一个数组
for (int i = 0; i < row; i++)
a[i] = new int[col];
// 遍历赋值
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
a[i][j] = i*col + j;
}
}
}
void DeleteArray(int **& a)
{
// 释放 要先从指针数组 里面的 数组开始释放,不然会出现内存泄漏
for (int i = 0; i < row; i++)
delete[] a[i];
// 如果先释放指针数组,否则里面的数组指针就没了 没了地址的数组就释放不了了
delete[] a;
}
void Show(int **& a)
{
for (int i = 0; i < row; i++)
{
for (int j = 0; j < col; j++)
{
cout << a[i][j] << '\t';
}
cout << endl;
}
}
转载地址:https://blog.csdn.net/weixin_33958381/article/details/117156497 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!
发表评论
最新留言
关于作者
