- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构试验报告01讲解
吉林大学
数据结构实验报告
班级: 软件4班
姓名:王禹力
学号
姓名王禹力学号实验项目数据结构单链表的操作实验性质□演示性实验 □验证性实验
?操作性实验 □综合性实验实验地点计算机楼B108机器编号43指导教师姜丽实验时间2016年 11 月 14日13时 2分一、实验目的及要求
二、实验设备、软件
PC,windows?XP Professional,C++
三、实验过程(算法设计、代码编写、程序调试、测试数据设计、测试、报告撰写)
算法设计:
链表的建立
首先利用构造函数来建议哨位节点。然后根据用户需要确定是从前添加,从末尾添加还是从中间添加。并且加入了size来确定链表长度
1.1从头添加
利用new 建立一个新的节点,然后让指向次节点的指针指向哨位节点的next。之后哨位节点的头指针指向新的节点,完成嵌入。
1.2从尾部添加
用new新建一个节点,并且找到链表中指针域next为空的节点,把此节点的next指向新的节点。令新的节点的next为空。Size+1。
1.3从中间插入
用new新建一个节点,并且找到要插入的前一个节点与后一个节点,把新节点的next指向后一个节点,然后前一个节点的next指向新节点,完成嵌入。并且size+1。
删除链表
2.1从头删除
代表选择删除的指针指向头指针的next。头指针的next指向他指向的节点的next。然后利用delete来释放代表选择删除的指针指向的节点。Size-1。
2.2从尾部删除
代表选择删除的指针指向next为空的指针,并且利用另一个指针把倒数第二 个节点的next设置为空。Size-1。
2.3从中间删除
代表选择删除的指针找到要删除的节点,另一个指针找到要删除的指针的前驱。前驱的next指向要删除的指针的next,然后delete要删除的节点。Size-1。
数据的存取
3.1当前数据的存取
直接通过指向当前节点的指针来操作节点的数据域。
3.2第k个元素的存取
定义变量i=0,让指针从头开始沿着链表的顺序读取,每读取一个,i+1。当i和k相等时,读取此时指针所指的节点的数据域。
代码编写
链表的建立
1.1从头部
if(front - next == NULL){
front - next = new ListNode;
front - next - node = p;
front - next - next = NULL;
now = rear = front-next;
}
else{
now = front - next;
front - next = new ListNode;
front - next - node = p;
front - next - next = now;
now = front-next;
}
++size;
1.2从尾部
if(front - next == NULL) push_front(p);
else{
now = rear;
rear = new ListNode;
rear - node = p;
rear - next = NULL;
now - next = rear;
}
now = rear;
++size;
1.3从中间
if(front - next == NULL) push_front(p);
else if(now == rear) push_back(p);
else{
ListNode *ptr = new ListNode;
ptr - node = p;
ptr - next = now - next;
now - next = ptr;
}
++size;
删除链表
2.1从头部
if(front - next == NULL) cout \n链表为空.\n;
else{
ListNode *ptr = front - next - next;
delete front - next;
front - next = now = ptr;
if(front - next == NULL){
rear = front;
now = front;
}
else now = front-next;
--size;
}
2.2从尾部
if(front - next == NULL) cout \n链表为空.\n;
el
您可能关注的文档
最近下载
- 中国云新南航空公司acars系统培训.ppt VIP
- 马克思主义宗教观87814.ppt VIP
- 《城市轨道交通通信与信号》教案 第11课 城市轨道交通通信系统(一).docx VIP
- 大众蔚领保养手册.docx VIP
- 部编人教版小学4四年级语文上册(全册)优秀教案设计.doc VIP
- 道德与法治新教材培训心得体会.pptx VIP
- 2026年高考化学大一轮复习第3讲离子共存 离子的检验与推断.pptx VIP
- 冯唐成事心法读书札记.docx VIP
- 第1课 时代精神的精华-【中职专用】2024年中职思想政治《哲学与人生》金牌课件(高教版2023·基础模块).pptx VIP
- 《新闻采访与写作》电子课件 第三章 新闻采写的客体——新闻事实.ppt VIP
文档评论(0)