顺序表的实现之动态分配
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);
}