多维数组的动态分配(二三维)
三天之内把伟大的Vibe算法搞懂了,今天用了一上午的时间把Vibe写了出来,结果一运行提示了一个“stack overflow”的错误,当时我那个心力憔悴呀。各种查找,各种百度,最后还是找到了相应的答案,在此记录一下,以作以后使用,对于我对伟大的Vibe算法的理解,稍后将会奉上:
//////////////c用malloc和free//////////////////////////////
#i nclude "stdio.h"
#i nclude "stdlib.h"
void main()
{
int **p;
int i,j; //p[4][8]
//开始分配4行8列的二维数据
p = (int**)malloc(sizeof(int*)*4);
for(i=0; i<4; i++)
p[i] = (int*)malloc(sizeof(int)*8);
for(i=0; i<4; i++)
for(j=0; j<8; j++)
p[i][j] = j*i;
//打印数据
for(i=0; i<4; i++)
for(j=0; j<8; j++)
{
if(j==0) printf("\n");
printf("%3d",p[i][j]);
}
//开始释放申请的堆
for(i=0; i<4; i++)
free(p[i]);
free(p);
}
///////////////////////////////////////////////////////////
//////////////c++用new和delete/////////////////////////////
#i nclude <iostream>
using namespace std;
void main()
{
int **p;
int i,j; //p[4][8]
//开始分配4行8列的二维数据
p = new int *[4];
for(i=0;i<4;i++)
p[i]=new int [8];
for(i=0; i<4; i++)
for(j=0; j<8; j++)
p[i][j] = j*i;
//打印数据
for(i=0; i<4; i++)
for(j=0; j<8; j++)
{
if(j==0) cout<<endl;
cout<<p[i][j]<<"\t";
}
//开始释放申请的堆
for(i=0; i<4; i++)
delete [] p[i];
delete [] p;
}
///////////////////////////////////////////////////////////
动态分配三维数组的程序
//////////////c用malloc和free//////////////////////////////
#i nclude "stdlib.h"
#i nclude "stdio.h"
void main()
{
int i,j,k; //p[2][3][4]
char ***p = (char***)malloc(2* sizeof(char**));
for(i=0; i<2; i++)
{
p[i] = (char**)malloc(3*sizeof(char*));
for(j=0; j<3; j++)
{
p[i][j] = (char*)malloc(4*sizeof(char));
}
}
//finish creating use p[i][j][k] to access the data
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
for(k=0;k<4;k++)
{
p[i][j][k]=i+j+k;
printf("%d ",p[i][j][k]);
}
printf("\n");
}
printf("\n");
}
//free the memory
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
free(p[i][j]);
}
}
for(i=0; i<2; i++)
{
free(p[i]);
}
free(p);
}
///////////////////////////////////////////////////////////
//////////////c++用new和delete/////////////////////////////
#i nclude <iostream>
using namespace std;
void main()
{
int i,j,k; // p[2][3][4]
int ***p;
p = new int **[2];
for(i=0; i<2; i++)
{
p[i]=new int *[3];
for(j=0; j<3; j++)
p[i][j]=new int[4];
}
//finish creating use p[i][j][k] to access the data
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
for(k=0;k<4;k++)
{
p[i][j][k]=i+j+k;
cout<<p[i][j][k]<<" ";
}
cout<<endl;
}
cout<<endl;
}
//free the memory
for(i=0; i<2; i++)
{
for(j=0; j<3; j++)
{
delete [] p[i][j];
}
}
for(i=0; i<2; i++)
{
delete [] p[i];
}
delete [] p;
}