多维数组的动态分配(二三维)

三天之内把伟大的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;  

原文地址:https://www.cnblogs.com/2011winseu/p/2601582.html