资源描述:
《实现单链表的各种基本运算》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、实现单链表的各种基本运算一、实验目的了解单链表表的结构特点及有关概念,掌握单链表的各种基本操作算法思想及其实现。二、实验内容 编写一个程序,实现顺序表的各种基本运算:1、初始化单链表; 2、单链表的插入; 3、单链表的输出; 4、求单链表的长度 5、判断单链表是否为空;6、输出单链表的第i位置的元素; 7、在单链表中查找一个给定元素在表中的位置; 8、单链表的删除; 9、释放单链表三、算法思想与算法描述简图主函数mainvoidInitList(LinkList*&L)初始化单链表Lvo
2、idDestroyList(LinkList*&L)//释放单链表LintListEmpty(LinkList*L)//判断单链表L是否为空集intListlength(LinkList*L)//返回单链表L的元素个数voidDispList(LinkListt*L)//输出单链表LintGetElem(LinkList*L,inti,chare)/*ElemTypee)获取单链表L中的第i个元素*/intLocateEmpty(LinkList*L,chare)/*ElemTypee)在单链表L中查找元素e*/intListInsert(LinkList*&L,inti,char
3、e)/*ElemTypee)在单链表中第i个位置上插入元素e*/intListDelete(LinkList*&L,inti,char&e)/*ElemTypee)在单链表L中删除第i个元素*/四、实验步骤与算法实现#include#includetypedefcharElemType;typedefstructLNode//定义单链表{ElemTypedata;structLNode*next;}LinkList;voidInitList(LinkList*&L){L=(LinkList*)malloc(sizeof(LinkList));/
4、/创建头结点L->next=NULL;//头结点赋值为空}voidDestroyList(LinkList*&L)//销毁单链表(释放单链表L占用的内存空间即逐一释放全部结点的空间){LinkList*p=L,*q=p->next;while(q!=NULL){free(p);p=q;q=p->next;}free(p);}intListEmpty(LinkList*L)//判线性表是否为空表ListEmpty(L){return(L->next==NULL);}//若单链表L没有数据结点,则返回真,否则返回假。intListLength(LinkList*L)//求线性表的长度L
5、istLength(L){LinkList*p=L;inti=0;while(p->next!=NULL){i++;p=p->next;}return(i);//返回单链表L中数据结点的个数}voidDispList(LinkList*L)//输出线性表DispList(L){LinkList*p=L->next;while(p!=NULL)//逐一扫描单链表L的每个数据结点,并显示各结点的data域值。{printf("%c",p->data);p=p->next;}printf("");}intGetELem(LinkList*L,inti,ElemType&e)//求线性
6、表L中指定位置的某个数据元素GetElem(L,i,&e){intj=0;LinkList*p=L;while(jnext;}if(p==NULL)return0;//不存在第i个数据结点else{e=p->data;//存在第i个数据结点return1;}}intLocateElem(LinkList*L,ElemTypee)//按元素值查找LocateElem(L,e){LinkList*p=L->next;intn=1;while(p!=NU
7、LL&&p->data!=e)//在单链表L中从头开始找第1个值域与e相等的结点,若存在这样的结点,则返回位置,否则返回0。{p=p->next;n++;}if(p=NULL)return(0);elsereturn(n);}intListInsert(LinkList*&L,inti,ElemTypee)//插入数据元素ListInsert(&L,i,e){intj=0;LinkList*p=L,*s;while(j