顺序表的实现之动态分配
#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
网友评论