现在的位置: 首页 > 综合 > 正文

动态数组

2017年10月05日 ⁄ 综合 ⁄ 共 1642字 ⁄ 字号 评论关闭

对动态数组的一些认识吧

看别人的博客有很好呢

动态数组:http://blog.csdn.net/bigloomy/article/details/6615012

内存分配函数:http://blog.chinaunix.net/uid-24227137-id-3143974.html


下面的我自己编写的一段代码,解释的很清楚


/**
**创建一个可以随时加减长度的动态数组
**对于二维及多维数组,只需要遵循下面的原则:
**1.创建时,从外层往里层,逐层创建
**2.释放时,从里层往外层,逐层释放
**/
#include <stdio.h>
#include <stdlib.h>

int main()
{
    typedef int ElemType;//方便以后可以任意变换类型
    ElemType *MyArray,*MyArray_Newbase;
    int i;
    int n1,n2;//n1表示起始创建的长度
              //n2表示需要加长和缩短的长度   缩短用负数
    printf("Pleae input the length of the array:\n");
    scanf("%d",&n1);

    /**
    **malloc声明是数组初始化是乱码
    **calloc声明的数组初始化是0
    **/
    //MyArray=(ElemType*)malloc(n1*(sizeof(ElemType)));
    MyArray=(ElemType*)calloc(n1,sizeof(ElemType));
    /*****检测是否创建成功*****/
    if(MyArray==NULL)
    {
        printf("The array creat fail!!!\n");
        exit(0);
    }

    //for(i=0;i<n1;i++)
      //  MyArray[i]=i;

    for(i=0;i<n1;i++)
    {
        printf("%5d ",MyArray[i]);
        //printf("%5d ",*(MyArray+i));
    }
    printf("\n");

    /***加长数组OR剪短数组 在于输入数据的正负****/
    printf("please input increase or decrease length:\n");
    scanf("%d",&n2);
    MyArray_Newbase=(ElemType*)realloc(MyArray,(n1+n2)*(sizeof(ElemType)));

    /*****检测是否创建成功*****/
    if(MyArray_Newbase==NULL)
    {
        printf("The array creat fail!!!\n");
        exit(0);
    }

    for(i=0;i<(n1+n2);i++)
        MyArray_Newbase[i]=i;

    for(i=0;i<(n1+n2);i++)
        printf("%5d",MyArray_Newbase[i]);
    printf("\n");

    /***释放内存**/
    free(MyArray);
    free(MyArray_Newbase);
    return 0;
}
<span style="font-size:24px;color:#ff0000;">以下话转自:http://blog.csdn.net/bigloomy/article/details/6615012</span>
动态多维数组定义原则:<span style="font-family: Arial; font-size: 14px; line-height: 26px;"><span style="color:#333333;">那就是在创建的时候</span><strong><span style="color:#3333ff;">从外层往里层,逐层创建;而释放的时候从里层往外层,逐层释放</span></strong><span style="color:#333333;">。这个话你读了可能理解并不深刻,不过不要急,接下来我们看看两段代码。(记住以上的原则,创建的时候会很好创建,逻辑很清楚,谢谢博主)。</span></span>

抱歉!评论已关闭.