标签:lidoublewen cout int c++ 二维 动态创建 数组 new
转载:https://blog.csdn.net/lidoublewen/article/details/4458819
c++动态创建二维数组
方法1:用一维数组代替二维数组
int n,m;
cin>>n>>m;
int* a = new int[ n*m];
for(int i = 0 ; i<n ; ++i)
{
cout<<endl;
for(int j = 0 ; j<m ; ++j)
{
a[i*m+j] = i+j;
cout<<a[i*m+j]<<" "<<&a[i*m+j]<<" ";
}
}
cout<<endl;
delete[] a;
运行结果:
0 00491BB0 1 00491BB4 2 00491BB8
1 00491BBC 2 00491BC0 3 00491BC4
2 00491BC8 3 00491BCC 4 00491BD0
各个元素的内存地址是递增的,是在堆区里分配的内存空间。
方法2:二维数组
int n,m;
cin>>n>>m;
int** a = new int*[n];/创建指针数组
for(int i = 0;i<n;i++)
{
a[i] = new int[m];为每一行分配空间
}
for(int f =0;f<n;f++)
{
for(int j =0;j<m;j++)
{
a[f][j] = f+j;为数组赋值
}
}
其实大家更关心二维数组在内存中是如何分配空间的:
输出每个元素的地址:
for(int k = 0;k<n;++k)
{
cout<<endl;
for(int s = 0;s<m;++s)
{
cout<<&a[k][s]<<" ";
}
}
输出结果:
00491B40 00491B44 00491B48
004918D0 004918D4 004918D8
00491890 00491894 00491898
每一行的相邻元素地址是递增的,连续的,不同行之间的地址就不连续了。
————————————————
版权声明:本文为CSDN博主「lidoublewen」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/lidoublewen/article/details/4458819
标签:lidoublewen,cout,int,c++,二维,动态创建,数组,new 来源: https://www.cnblogs.com/MCSFX/p/15321605.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。