二維陣列的引數傳遞
阿新 • • 發佈:2019-02-09
參考原文:
http://blog.csdn.net/u013752202/article/details/49688717
方法一:
通過陣列名傳遞,形參的第一維寬度可以省,但是第二維引數不可以省略。
void f1(int a[][4]) //或者a[3][4],第二維陣列不能省。
{
cout << a[1][1]; //5
}
int main()
{
int a[3][4] = { {1,2,3,1},{4,5,6,7},{8,9,10,11} };
f1(a);
}
方法二:
指標傳遞,將陣列第幾行的首地址給指標。
void f2(int *p) { cout << *p; //4,當p+5後就是第二組的第二個元素 } int main() { int a[3][4] = { {1,2,3,1},{4,5,6,7},{8,9,10,11} }; f2(a[1]); //將第二行的第一個元素的位置給p }
方法三:
二級指標傳遞。
void f3(int **p)
{
cout << *((int *)p+5 );
}
int main()
{
int a[3][4] = { {1,2,3,1},{4,5,6,7},{8,9,10,11} };
f3( (int**)a);
while (1);
}
方法四:
這種方法在函式內部可以使用[]符號訪問陣列元素,但是在呼叫函式前必須先開闢一段二級指標指向的記憶體,然後把陣列值拷貝到這一塊記憶體中,用完後必須手動釋放記憶體。優點是同一個函式可以接收不同長和寬的二維陣列,缺點是必須手動開闢一段記憶體用完後還要手動回收,並且要把二維陣列的值拷貝到開闢的記憶體中
void print(float **tab,int rows,int cols) { for(int i=0;i<rows;i++){ for(int j=0;j<cols;j++){ cout<<tab[i][j]<<" "; } cout<<endl; } } int main() { float ta[2][3]={{1.0,2.0,3.0},{4.0,5.0,6.0}}; float **p=new float *[2];//開闢行空間 for(int i=0;i<3;i++) p[i]=new float[i];//開闢列空間 for(int i=0;i<2;i++){ //賦值 for(int j=0;j<3;j++){ p[i][j]=ta[i][j]; } } cout<<"ta: "<<endl; print(p,2,3);//列印 //p的記憶體釋放方式 for(int i=0;i<3;i++) delete[]p[i]; delete []p; }