- 1、本文档共11页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
北邮数据结构实验报告实验一线性表sy0bf2od
数据结构实验报告
实验名称: 实验一线性表——题目1
学生姓名: 申宇飞
班 级: 信通3班
班内序号: 03
学 号: 2012210064
日 期: 2013年11月4日
实验要求
实验目的:
熟练掌握线性表的基本操作,包括:创建、插入、删除、查找、输出、求长度、合并等运算,以及各类操作在顺序存储结构和链式存储结构上的实现。
实验内容:
根据线性表的抽象数据类型的定义,选择下面任一种链式结构实现线性表,并完成线性表的基本功能。
线性表存储结构(五选一):
带头结点的单链表
不带头结点的单链表
循环链表
双链表
静态链表
线性表的基本功能:
构造:使用头插法、尾插法两种方法
插入:要求建立的链表按照关键字从小到大有序
删除
查找
获取链表长度
销毁
其他:可自行定义
编写测试main()函数测试线性表的正确性。
程序分析
2.1 存储结构
链表的具体存储表示为:
① 用一组任意的存储单元来存放线性表的结点(这组存储单元既可以是连续的,也可以是不连续的)
② 链表中结点的逻辑次序和物理次序不一定相同。为了能正确表示结点间的逻辑关系,在存储每个结点值的同时,还必须存储指示其后继结点的地址信息(称为指针)
链表的结点结构? ┌──┬──┐? │data│next│? └──┴──┘?????? data域--存放结点值的数据域????? next域--存放结点的直接后继的地址(位置)的指针域(链域)
地址 内存单元
a[3]
1080H
……
a[1]
10C0H
……
a[4]
^
……
a[2]
1000H
……
1000H
头指针 1020H
1080H
10C0H
front …………
2.2 关键算法分析
1、关键算法:
1:头插法
自然语言描述:
a:在堆中建立新结点
b:将a[i]写入到新结点的数据域
c:修改新结点的指针域
d:修改头结点的指针域。将新结点加入链表中
伪代码描述
a:Node T * s=new Node T
b:s-data=a[i]
c:s-next=front-next;
d:front-next=s
2:尾插法
自然语言描述:
a:在堆中建立新结点:
b:将a[i]写入到新结点的数据域:
c:将新结点加入到链表中
d:修改修改尾指针
伪代码描述
a:Node T * s=new Node T
b:s-data=a[i]
c:r-next=s;
d:r=s
3:析构/删除函数
自然语言描述:
a:新建立一个指针,指向头结点
b:判断要释放的结点是否存在,
c:暂时保存要释放的结点
d:移动a中建立的指针
e:释放要释放的指针
伪代码描述
a:Node T * p=front
b:while(p)
c:front=p
d:p=p-next
e:delete front
4:按位查找函数
自然语言描述:
a:初始化工作指针p和计数器j,p指向第一个结点,j=1
b:循环以下操作,直到p为空或者j等于1
b1:p指向下一个结点
b2:j加1
c:若p为空,说明第i个元素不存在,抛出异常
d:否则,说明p指向的元素就是所查找的元素,返回元素地址
伪代码描述
a:Node T * p=front-next;j=1;
b:while(pj!=1)
b1:p=p-next
b2:j++
c:if(!p) throw ”error”
d:return p
5:按位查找函数
自然语言描述:
a:初始化工作指针p和计数器j,p指向第一个结点,j=1
b:循环以下操作,找到这个元素或者
您可能关注的文档
- 北师大版九年级物理上册期中试卷uaaenb8a.doc
- 北师大版一年级语文上册我 家住在大海边hfpflvqe.ppt
- 北师大版九年级物理第十三章《电功和电功率》同步练习tgbjcpxn.doc
- 北师大版七年级历史下册期末复习——课标解读及考点分析cbmiuulk.ppt
- 北大荒的秋天yo3xjhcz.ppt
- 北师大版二年级上册语文教学工作计划a3y0yni9.doc
- 北师大版二年级语文下册教学计划hddinqw7.doc
- 北师大版六年级上册品社教学计划jur4cfw7.doc
- 北师大版五下组合图形面积efvlicpw.ppt
- 北师大版六年级语文上册期中测试题22erntxlk.doc
- 中国国家标准 GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18233.4-2024信息技术 用户建筑群通用布缆 第4部分:住宅.pdf
- GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- 《GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计》.pdf
- 中国国家标准 GB/T 18978.210-2024人-系统交互工效学 第210部分:以人为中心的交互系统设计.pdf
- GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- 《GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置》.pdf
- 中国国家标准 GB/T 16649.2-2024识别卡 集成电路卡 第2部分:带触点的卡 触点的尺寸和位置.pdf
- GB/T 17889.4-2024梯子 第4部分:铰链梯.pdf
- 《GB/T 17889.4-2024梯子 第4部分:铰链梯》.pdf
文档评论(0)