本篇内容介绍了“C++如何实现线性表顺序存储”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
顺序表的特点:
需要一片连续的存储空间
逻辑上相连的数据的存储位置也是相邻的。
所以如果我们想要创建一个顺序表我们需要做两件事:
向系统申请一片空间供数组使用。
创建一个指针记录空间地址。
而删除顺序表就是把空间释放,并让指针指向空。
顺序表的创建和销毁:
#include<iostream>#include<cstdlib>#define EleType int//方便日后使用#define Maxsize 1000using namespace std;//定义结构体struct sql{ int* elem; int len;//防止越界访问};//初始化void InitList(sql &l){ l.elem=new int [Maxsize]; if(!l.elem) cout<<"申请空间失败"<<endl; l.len=0;}//销毁线性表void DestroyList(sql &l){ delete [] l.elem; l.elem=nullptr;}int main(){ sql l; InitList(l); return 0;}
数据的插入和删除:
因为在顺序存储所有的数据的存储地址是连续的,所以在插入和删除数据时你需要改变后续的所有数据的位置。在插入时把后面的数据往后挪,删除时把数据向前挪。
void adds(sql &l,EleType target,int sit){ if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"<<endl;//插入位置错误 exit(0); } if(l.len+1>Maxsize) { cout<<"Too many"<<endl;//存储空间已满 exit(0); } //把后面的数据往后挪 for(int i=l.len-1;i>=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"<<endl; exit(0); } for(int i=sit-1;i<l.len;i++) { l.elem[i]=l.elem[i+1]; } l.len--;//更新表长}
其他操作:
查找和更改:
//查找int finding(sql l,EleType target){ for(int i=0;i<l.len;i++) { if(l.elem[i]==target) return i+1; } return 0;}//更改void Changing(sql& l,int sit,EleType target){ if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"<<endl; exit(0); } l.elem[sit-1]=target;}
清空、获取长度、判断是否为空:
//清空线性表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<iostream>#include<cstdlib>#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<<"申请空间失败"<<endl; l.len=0;}//输出void print(sql l){ for(int i=0;i<l.len;i++) { cout<<l.elem[i]<<" "; } cout<<endl;}//插入void adds(sql &l,EleType target,int sit){ if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"<<endl; exit(0); } if(l.len+1>Maxsize) { cout<<"Too many"<<endl; exit(0); } for(int i=l.len-1;i>=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"<<endl; exit(0); } for(int i=sit-1;i<l.len;i++) { l.elem[i]=l.elem[i+1]; } l.len--;}//销毁线性表void DestroyList(sql &l){ delete [] l.elem;}//清空线性表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;}//查找int finding(sql l,EleType target){ for(int i=0;i<l.len;i++) { if(l.elem[i]==target) return i+1; } return 0;}//更改void Changing(sql& l,int sit,EleType target){ if(sit>l.len+1 || sit <1) { cout<<"sit is wrong"<<endl; exit(0); } l.elem[sit-1]=target;}int main(){ sql l; InitList(l); EleType j=0; for(int i=1;i<10;i++,j++) adds(l,j,i); DeletElem(l,2); print(l); return 0;}
“C++如何实现线性表顺序存储”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注编程网网站,小编将为大家输出更多高质量的实用文章!