1. 程式人生 > 其它 >c++動態建立二維陣列

c++動態建立二維陣列

轉載: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