
常用的有以下幾種二維數組的表示方法:
(1)、第一種是普通的二維數組的表示方法。
(2)、第二種是用一維數組來表示二維數組,從顯示的元素地址可以看出,二維數組和一維數組表示的二維數組在內存中的儲存方式其實是一樣的,不過使用二維數組看起來要簡單些,只要不用進行地址轉換。
(3)、第三種表示是用指針數組。本例中的c[i]中的元素其實是地址。這種方法對各個元素大小不一樣的情況下比較適用。如:假定有若干個不等長字符串需要我們處理,如果使用a [i ][j]結構,則j必須取這些字符串長度的最大值, 顯然這種方法浪費空間。如果采用* a [i ]結構,則由於a中僅保存每個字符串的首地址,而不是串本身,這不僅節約了空間,而且減少了直接對串進行操作的時間。
(4)、第四種方式為用指向指針的變量來表示。此種方式p是指向指針的指針,不能把普通的二維數組的首地址(如本例中的a)賦給它。(因為a不是指向指針的指針)。可以把第三種方式中的數組指針的首地址賦給它。這種方式用的較少。
#include<iostream>
using namespace std;
int main()
{
int a[3][3] = {{0,1,2},{3,4,5},{6,7,8}};
int b[9] = {0,1,2,3,4,5,6,7,8};
int *c[3];
int **p;
cout<<"普通二維數組表示"<<endl;
for(int i = 0;i<3;++i)
{
for(int j = 0;j<3;++j)
{
cout<<a[i][j]<<"("<<&a[i][j]<<")"<<" "; //括號里是對應元素的地址
//cout<<*(*(a+i)+j)<<" ";
}
cout<<endl;
}
cout<<"普通一維數組表示"<<endl;
for(int i = 0;i<3;++i)
{
for(int j = 0;j<3;++j)
{
cout<<b[i*3+j]<<"("<<&b[i*3+j]<<")"<<" ";
}
cout<<endl;
}
cout<<"指針數組表示:"<<endl;
for(int i = 0;i<3;++i)
{
c[i] = *(a+i); //c[i]指向a數組的第i行首地址
for(int j = 0;j<3;++j)
{
cout<<c[i][j]<<"("<<&c[i][j]<<")"<<" ";
}
cout<<endl;
}
cout<<"指針變量表示"<<endl;
p = c; //p為指向指針的指針,將指針數組c賦給指針變量p
for(int i = 0;i<3;++i)
{
for(int j = 0;j<3;++j)
{
cout<<p[i][j]<<"("<<&p[i][j]<<")"<<" ";
}
cout<<endl;
}
return 0;
}
最后
特別推薦一個分享C/C++和算法的優質內容,學習交流,技術探討,面試指導,簡歷修改...還有超多源碼素材等學習資料,零基礎的視頻等着你!
還沒關注的小伙伴,可以長按關注一下:
