- 1、本文档共8页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话: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;else{ListNode *ptr = front; //指向哨位节点while(ptr - next != rear) ptr = ptr - next;delete rear;now = ptr; //now 指向尾节点rear = ptr;ptr - next = NULL;--size;}2.3从中间if(size == 0 || now == rear) cout \n无法删除当前节点的后继节点\n;else if(now - next == rear){delete r
您可能关注的文档
- 数字信号处理实验4详解.docx
- 数字信号处理实验一离散卷积的C语言编程详解.ppt
- 数字信号处理(第二版)实验程序代码及结果详解.docx
- 数字信号处理实验报告四电子版详解.doc
- 数字信号处理实验10.4详解.pptx
- 数字信号处理试验源程序详解.doc
- EMS标准培训课件.pptx
- 数字信号实验详解.doc
- EN50306-42002薄壁型铁道机车车辆阻燃电缆(第四篇)课件.doc
- 数字化变电站改造毕业论文详解.doc
- 七章货物的保险.pptx
- 三章国际间接投资.pptx
- 人性假设理论.pptx
- 外研高一英语必修三ModuleIntroduction汇总市公开课获奖课件省名师示范课获奖课件.pptx
- 月相成因优质获奖课件.pptx
- 小学二年级语文课件《狐假虎威》省名师优质课赛课获奖课件市赛课一等奖课件.pptx
- 养羊业概况专题知识讲座.pptx
- 微生物的实验室培养市公开课获奖课件省名师示范课获奖课件.pptx
- 人教版六年级下册式与方程整理与复习市公开课获奖课件省名师示范课获奖课件.pptx
- 必威体育精装版高中精品语文教学:第二单元-第7课-诗三首:涉江采芙蓉、-短歌行、归园田居市公开课获奖课件省名师.pptx
文档评论(0)