1. 程式人生 > >如何動態分配二、三維陣列

如何動態分配二、三維陣列

本文主要目的是用c和c++分別實現動態分配二、三維陣列。一般而言,在C中用malloc和free實現,而在C++中用new和delete。 new和delete是c++操作符,malloc和free是c語言函式,它們都可以用來為物件動態分配空間,最大的區別在於:當用new和 delete為物件分配空間或delete物件時,將預設的呼叫物件的建構函式及析購函式,而malloc和free是原來c庫中的函式,顯然沒有這項功 能,因此,在c++中,最好使用new和delete。

動態分配二維陣列的程式
//////////////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;  

}