三维数组有点不好理解。很多人认为可以用 数组的数组来进行理解,或者可以用立方体来理解。而我认为可以用 树结构来理解。比如 int array【3】【4】【5】,可以认为从根节点出来,首先有3个一级节点,每个一级节点有4个二级节点,每个二级节点有5个三级节点。
三维数组的动态分配,要注意delete,如下:
int z = 2;
int y = 5;
int x = 6;
int ***pppint = new int**[z];
for(int k = 0; k < z; k++)
{
pppint[k] = new int*[y];
for(int j = 0; j < y; j++)
{
pppint[k][j] = new int[x];
for(int i = 0; i < x; i++)
{
pppint[k][j][i] = 0xCCCCCCCC;
}
}
}
for(int ak = 0; ak < z; ak++)
{
for(int aj = 0; aj < y; aj++)
{
for(int ai = 0; ai < x; ai++)
{
pppint[ak][aj][ai] = (ak+1)*0x11111111;
}
}
}
for(int dk = 0; dk < z; dk++)
{
for(int dj = 0; dj < y; dj++)
{
delete[] pppint[dk][dj];
}
delete[] pppint[dk];
}
delete[] pppint;