动态创建二维数组
int **p;
p = new int*[10];??? //注意,int*[10]表示一個(gè)有10個(gè)元素的指針數(shù)組
for (int i = 0; i != 10; ++i)
{
??? p[i] = new int[5];
}
這里是將p作為一個(gè)指向指針的指針,它指向一個(gè)包含10個(gè)元素的指針數(shù)組,并且每個(gè)元素指向一個(gè)有5個(gè)元素的數(shù)組,這樣就構(gòu)建了一個(gè)10行5列的數(shù)組。
當(dāng)數(shù)組使用完畢,釋放空間的代碼是:
for(int i = 0; i != 5; i++)
{
??? delete[] p[i];
}
?delete[] p;
處理二維數(shù)組,可以用降維或是二維法。
降維法是用一位數(shù)組來(lái)接受二維數(shù)組,將二維元素的首地址&a[0][0]作為參數(shù),傳遞給函數(shù),函數(shù)用int *接受。
二維法就直接用二維數(shù)組來(lái)接受,但是需要指定列數(shù)。
?
?
?
?
如要想創(chuàng)建一個(gè)[m][n]的二維數(shù)組。
下面為通過(guò)動(dòng)態(tài)創(chuàng)建一個(gè)指針數(shù)組的方法來(lái)動(dòng)態(tài)創(chuàng)建二維數(shù)組的方法。
C版本:
?double **data;
?data = (double **)malloc(m*sizeof(double *));
?for(int j=0;j<m;j++)
?{
??data[j] = (double*)malloc(n*sizeof(double));??//這個(gè)指針數(shù)組的每個(gè)指針元素又指向一個(gè)數(shù)組。
?}
?
?for (int i=0;i<m;i++)
?{
??for (int j=0;j<n;j++)
??{
???data[i][j]=i*n+j;//初始化數(shù)組元素
??}
?}
?for (i=0;i<m;i++)
?{
??free(data[i]);?//先撤銷指針元素所指向的數(shù)組
?}??????????????
?free(data);
?
C++版本:
double **data;
data = new double*[m];?//設(shè)置行 或直接double **data=new double*[m]; 一個(gè)指針指向一個(gè)指針數(shù)組。
for(int j=0;j<m;j++)
{
data[j] = new double[n];??????? //這個(gè)指針數(shù)組的每個(gè)指針元素又指向一個(gè)數(shù)組。
}
for (int i=0;i<m;i++)
{
?? for (int j=0;j<n;j++)
?? {
??? data[i][j]=i*n+j;//初始化數(shù)組元素
?? }
}
for (i=0;i<m;i++)
{
?delete[] data[i]; //先撤銷指針元素所指向的數(shù)組
}?????????????????????
delete[] data;?
?
這種方法是通過(guò)先動(dòng)態(tài)創(chuàng)建一個(gè)指針數(shù)組,然后為指針數(shù)組的每個(gè)元素再動(dòng)態(tài)指向一個(gè)數(shù)組的辦法來(lái)完成的。其創(chuàng)建過(guò)程與銷毀過(guò)程兩樣重要。
在銷毀的過(guò)程,先銷毀指針數(shù)組每個(gè)元素指向的數(shù)組,然后再銷毀這個(gè)指針數(shù)組。
總結(jié)
- 上一篇: Windows驱动程序调用约定
- 下一篇: 毕业两年的我--奋斗中的程序员