单链表的存储与操作

单链表的存储与操作

ID:23404933

大小:157.24 KB

页数:8页

时间:2018-11-06

单链表的存储与操作_第1页
单链表的存储与操作_第2页
单链表的存储与操作_第3页
单链表的存储与操作_第4页
单链表的存储与操作_第5页
资源描述:

《单链表的存储与操作》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、成绩评阅人重庆邮电大学课程设计实验报告班级:1301416姓名:陈昊学号:2014214156指导老师:夏晨洋课程名称:数据结构实验时间:2015年10月26日-2015年11月2日实验地点:数字图书馆负一楼B132实验二单链表的存储与操作一、实验目的1.理解线性表的逻辑结构;2.理解单链表的存储结构特点,掌握单链表的存储分配要点;3.掌握单链表的基本操作及实现,并能正确分析其时间复杂度。二、主要数据结构描述LinkList();//建立只有头结点的空链表LinkList(Ta[],intn);//建立有n个元素的单链表~LinkList();//析构函数intLength();//求单链

2、表的长度TGet(inti);//取单链表中第i个结点的元素值intLocate(Tx);//求单链表中值为x的元素序号voidInsert(inti,Tx);//在单链表中第i个位置插入元素值为x的结点TDelete(inti);//在单链表中删除第i个结点voidPrintList();//遍历单链表,按序号依次输出各元素Node*first;//单链表的头指针在单链表中,需要有构造函数用来构造整个单链表。需要析构函数来删除整个单链表。需要一个Length函数来求单链表的长度。需要一个取值函数Get,传入节点的编号,返回节点的值。需要一个求序号的函数,传入数据的值,返回数据对应的

3、编号,即在单链表中的位置。需要一个插入函数,用来在特定的位置插入一个节点用来存储新数据。需要一个删除函数,用来删除某个节点,并将该节点两端的节点连起来。需要一个遍历函数,用以遍历单链表。三、算法的基本思想描述1.按位置/值查找:按位置和按值查找的思路大体相同,需要一个工作指针来对整个链表进行遍历,如果所遇到的编号或值与想要的一致,便会把工作指针的信息返回。此函数只需对链表遍历一次,所以平均时间复杂度为O(n);2.在位置i插入一个数据元素:此函数可以大体分成两个部分。第一个部分是遍历,寻找到要插入的位置,这个与上面的方法相同。第二个部分是插入,要先申请一个新节点s,在让s的指针域等于前一个

4、节点p的指针域,最后让p的指针域等于s。此函数只需对链表遍历一次,所以平均时间复杂度为O(n);3.删除位置i的数据元素:删除函数也有两个部分,第一个与插入相同,第二个先要暂存被删节点,用以返回,再让前一个节点的指针域等于后一个节点,最后删除被删节点。此函数只需对链表遍历一次,所以平均时间复杂度为O(n);4.初始化单链表(有参):有前插法和尾插法,实际上都是在链表的后面再添加一个新节点,所以时间复杂度为O(n);5.遍历单链表、求单链表长度、销毁单链表:这三个函数都是要遍历单链表,所以时间复杂度为O(n)。四、运行的结果截图五、实验体会和收获通过这次试验,我熟悉了如何取单链表中第i个结点

5、的元素值,如何按位查找位置为i的元素并输出值,如何构建一个单链表。总之这次试验然我熟悉了很多单链表的操作。六、程序清单。LinkList.hLinkList.cppLinkListMain.cpp

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。