顺序表的实现之动态分配

2021-03-25  本文已影响0人  爱生活_更爱挺自己
#define InitSize 10 //顺序表的初始长度

typedef struct
{
    int *data;      //指示动态分配数组的指针
    int MaxSize;    //顺序表的最大容量
    int length;     //顺序表的当前长度
}SqList;    //顺序表的类型定义

void InitList(SqList &L)
{
    //用malloc函数申请一片连续的存储空间
    L.data = (int *)malloc(InitSize * sizeof(int));
    L.length = 0;
    L.MaxSize = InitSize;
}

//增加动态数组长度
void IncreaseList(SqList &L, int len)
{
    int *p = L.data;
    L.data = (int *)malloc((L.MaxSize+len) * sizeof(int));
    for (int i=0; i<L.length; i++)
    {
        L.data[i] = p[i];   //将数据复制到新区域
    }
    L.MaxSize = L.MaxSize+len;
    free(p);
}
上一篇 下一篇

猜你喜欢

热点阅读