C++如何实现线性表顺序存储
顺序表的特点:
需要一片连续的存储空间
逻辑上相连的数据的存储位置也是相邻的。
所以如果我们想要创建一个顺序表我们需要做两件事:
向系统申请一片空间供数组使用。
创建一个指针记录空间地址。
而删除顺序表就是把空间释放,并让指针指向空。
顺序表的创建和销毁:
#include#include #define EleType int//方便日后使用 #define Maxsize 1000 using namespace std; //定义结构体 struct sql{ int* elem; int len;//防止越界访问 }; //初始化 void InitList(sql &l) { l.elem=new int [Maxsize]; if(!l.elem) cout<<"申请空间失败"< 数据的插入和删除:
因为在顺序存储所有的数据的存储地址是连续的,所以在插入和删除数据时你需要改变后续的所有数据的位置。在插入时把后面的数据往后挪,删除时把数据向前挪。
void adds(sql &l,EleType target,int sit) { if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"<Maxsize) { cout<<"Too many"< =sit-1;i--) { l.elem[i+1]=l.elem[i]; } l.elem[sit-1]=target; l.len++;//更新表长 } //删除元素 void DeletElem(sql &l,int sit) { if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"< 其他操作:
查找和更改:
//查找 int finding(sql l,EleType target) { for(int i=0;il.len+1 || sit <1) { cout<<"sit is wrong"< 清空、获取长度、判断是否为空:
//清空线性表 void ClearLine(sql &l) { l.len=0; } //获取线性表的长度 int Getlen(sql l) { return l.len; } //判断线性表是否为空 bool IsEmpty(sql l) { if(l.len==0) return true; return false; }完整代码
#include#include #define Maxsize 1000 #define EleType int//方便日后使用 using namespace std; //创建结构体 struct sql{ EleType* elem;//创建一个指针 int len; }; //初始化 void InitList(sql &l) { l.elem=new EleType [Maxsize]; if(!l.elem) cout<<"申请空间失败"< l.len+1 || sit <1) { cout<<"sit is wrong"< Maxsize) { cout<<"Too many"< =sit-1;i--) { l.elem[i+1]=l.elem[i]; } l.elem[sit-1]=target; l.len++; } //删除元素 void DeletElem(sql &l,int sit) { if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"< l.len+1 || sit <1) { cout<<"sit is wrong"<