1. 程式人生 > >二維陣列的引數傳遞

二維陣列的引數傳遞

參考原文:

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;  

}