zoukankan      html  css  js  c++  java
  • 多维数组的动态分配(二三维)

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

  • 相关阅读:
    Java中用Apache POI生成excel和word文档
    openlayers实现画圆
    openlayers实现wfs属性查询和空间查询
    jquery自定义控件拖拽框dragbox
    基于openlayers实现聚类统计展示
    openlayers实现在线编辑
    openlayers之selectfeature
    J
    HDU-1051Wooden Sticks
    HDU-1087Super Jumping! Jumping! Jumping!
  • 原文地址:https://www.cnblogs.com/2011winseu/p/2601582.html
Copyright © 2011-2022 走看看