顺序表的实现之动态分配

#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

你可能感兴趣的:(顺序表的实现之动态分配)