重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
这篇文章主要讲解了C++如何实现单链表的构造,内容清晰明了,对此有兴趣的小伙伴可以学习一下,相信大家阅读完之后会有帮助。
网站建设哪家好,找成都创新互联!专注于网页设计、网站建设、微信开发、小程序设计、集团企业网站建设等服务项目。为回馈新老客户创新互联还提供了江孜免费建站欢迎大家使用!
单链表的构造,包括最常用函数,setData(),Insert(),Remove(),getData(),Search()。
代码如下:
#include#include using namespace std; template struct LinkNode{ T data; LinkNode *link; LinkNode(LinkNode *ptr=NULL){link=ptr;} LinkNode(const T& item, LinkNode *ptr=NULL){data=item; link=ptr;} }; template class List{ public: List(){first=new LinkNode ;} List(const T& x){first=new LinkNode (x);} List(List &L); ~List(){makeEmpty();} void makeEmpty(); int Length()const; LinkNode *getHead()const{return first;} LinkNode *Search(T x); LinkNode *Locate(int i); bool getData(int i, T &x)const; void setData(int i,T &x); bool Insert(int i,T &x); bool Remove(int i, T &x); bool IsEmpty()const{return (first->link==NULL)?true:false;} bool IsFull()const{ return false;} void Sort(); void inputFront(T endTag); void inputRear(T endTag); void output(); List & operator=(List &L); private: LinkNode *first; }; template void List ::makeEmpty(){ //if(first->link==NULL)return; LinkNode *p=first->link; while(p!=NULL){ first->link=p->link; delete p; p=first->link; } } template LinkNode *List ::Search(T x){ LinkNode *p=first->link; while(p!=NULL){ if(p->data==x)break; p=p->link; } return p;//无论是否找到都返回p,若找到则返回p,没有则返回空指针 } template LinkNode *List ::Locate(int i){ //这个定位函数的作用还是非常大的,方便后来的函数根据i定位到相应位置的节点 if(i<0)return NULL; int sum=0; LinkNode *p=first; while(p!=NULL&&sumlink; } return p;//无论是否为空指针,返回的都是到达i位置的指针,如果没有到达就是已经到结尾了 } template bool List ::getData(int i, T& x)const{ if(i<0)return false; LinkNode *p=Locate(i); if(p==NULL)return false; else{ x=p->data; return true; } } template void List ::setData(int i, T& x){ if(i<0)return; LinkNode *p=Locate(i); if(p==NULL)return; else{ p->data=x; } } template bool List ::Insert(int i, T &x){ //LinkNode *pre=Locate(i-1); //这里是指插入到第i个元素之后的情况 LinkNode *cur=Locate(i); if(cur==NULL)return false; LinkNode *p=new LinkNode (x); if(p==NULL){cerr<<"存储分配错误!"< link=cur->link; cur->link=p; return true; } } template bool List ::Remove(int i, T& x){ //删除第i个位置的元素 LinkNode *pre=Locate(i-1); if(pre==NULL)return false; LinkNode *current=pre->link; if(current==NULL)return false; x=current->data; pre->link=current->link; delete current; return true; } template void List ::output(){ LinkNode *current=first->link; while(current!=NULL){ cout< data<<" "; current=current->link; } } template List & List ::operator=(List & L){ //这是赋值方法 LinkNode *srcptr=L.getHead(), *p=srcptr->link; LinkNode *desptr=first=new LinkNode ; T value; while(p!=NULL){ value=p->data; desptr->link=new LinkNode (value); desptr=desptr->link; p=p->link; } return *this; //用上面这种方法可以更好地实现赋值 // LinkNode *pre=L.getHead(); // if(pre==NULL){ // first=NULL; // return *this; // } // LinkNode *p=first=new LinkNode ; // first->link=p; // int sum=L.Length(); // T &x; // int i=1; // while(i<=sum){ // L.getData(i++,x); // p=new LinkNode (x); // p=p->link; // } // return *this; } template int List ::Length()const{ int sum=0; LinkNode *p=first->link; while(p!=NULL){ sum++; first->link=p->link; delete p; p=first->link; } return sum; } //前插法建立单链表 template void List ::inputFront(T endTag){ LinkNode *newNode; T value; makeEmpty(); cin>>value; while(value!=endTag){ newNode=new LinkNode (value); if(newNode==NULL){cerr<<"内存分配错误!"< link=first->link; first->link=newNode; cin>>value; } } //后插法建立单链表 template void List ::inputRear(T endTag){ LinkNode *newNode=new LinkNode , *last; T value; last=first=new LinkNode ; cin>>value; while(value!=endTag){ newNode=new LinkNode (value); if(newNode==NULL){cerr<<""< link=newNode; last=newNode; cin>>value; } } //复制构造函数 template List ::List(List &L){ //复制构造函数 T value; LinkNode *srcptr=L.gethead(), p=srcptr->link; LinkNode *desptr=first->link=new LinkNode ; while(p!=NULL){ value=p->data; desptr=new LinkNode (value); desptr=desptr->link; p=p->link; } }
看完上述内容,是不是对C++如何实现单链表的构造有进一步的了解,如果还想学习更多内容,欢迎关注创新互联行业资讯频道。