数据结构试验报告01讲解.docx

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 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

文档评论(0)

shuwkb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档