美文网首页
顺序表的实现之动态分配

顺序表的实现之动态分配

作者: 爱生活_更爱挺自己 | 来源:发表于2021-03-25 20:34 被阅读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);
}

相关文章

网友评论

      本文标题:顺序表的实现之动态分配

      本文链接:https://www.haomeiwen.com/subject/imhibktx.html