[实验一线性表的基本操作及其应用.docVIP

[实验一线性表的基本操作及其应用.doc

  1. 1、本文档共19页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[实验一线性表的基本操作及其应用

实验一 线性表的基本操作及其应用 实验目的 1、帮助读者复习C++语言程序设计中的知识。 2、熟悉线性表的逻辑结构。 3、熟悉线性表的基本运算在两种存储结构上的实现,其中以熟悉链表的操作为侧重点。题目一:单链表的基本操作(*) 题目二:约瑟夫环(**) [问题描述] 实现带头结点的单链表的建立、求长度,取元素、修改元素、插入、删除等单链表的基本操作。 [基本要求] (2)输出单链表中的数据元素 [测试数据] 由学生任意指定。 Data *next 主要思想: 插入: 删除: 本函数包含八个模块 主函数int main() :初始化一个链表L,显示菜单,主要语句:switch语句,while语句,goto语句。 创建并输入链表数据linklist createlist(),在该函数中创建头结点,并输入结点上的数据。 伪代码:while(当x!=00) { p = new list; p-data = x; p-next = NULL; q-next = p; q = p; } 显示链表数据void show(linklist L) 先判断是否是空表,再逐个寻找想要的元素。 主要代码: while(p) { coutp-data\t; p = p-next; } 获取链表长度int getlength(linklist L) 先判断是否为空,再遍历链表,算出链表长度。 主要代码: while(p) { p = p-next; length++; } 获取第i个元素int getdata(linklist L,int i) 1)当0ilength时,遍历链表,找到第i个元素。 2)主要代码: while(pji) { j++; p = p-next; } 改变链表数据int changedata(linklist L,int e,int d) 1)找到要修改的值e,再把d赋值给e. 2)主要代码: while(pp-data!=e) { p = p-next; } if(!p) return ERROR; p-data = d; 插入一个结点linklist insertlist(linklist L,int i,int e) 1)因为要插入第i个元素,所以要先找到第i-1个元素,在i-1后面插入。 2)主要代码: s-data = e; s-next = p-next ; p-next = s; 删除一个结点linklist deletelist(linklist L,int i) 1)同插入差不多,先找到第i-1个元素,然后再把i-1结点指针域指向原本指向结点的下一个,把中间那个删除,再free,释放空间, 主要代码: q = p-next; p-next =q-next; free(q); 实验过程 图1、登陆界面 图2、功能键1,2,3,4的实现 图3、功能键5、6的实现 图4、功能键7、0的实现 六、调试及感受 又是一次课设时,每次写程序总会遇到大大小小的毛病,就不断的调试调试,觉得写代码是需要很大的耐心,一直琢磨,一直分析,一直改,直至完美。可是当代码运行到自己想要的程度时,内心是那么的自豪,那么的傲娇,那么的兴奋,仿佛心长了翅膀似的,飞到高空翱翔去了,呵呵,感觉不错。不过,我希望自己下次不用再借鉴网上的代码,就能够自己迎仞有余,加油,我可以的! 并且谢谢老师的教导,老师您辛苦了!!! 七、源代码 #includeiostream #includestdio.h #includemalloc.h #define ERROR -1; using namespace std; typedef struct node{ int data; node *next; }list,*linklist; linklist createlist()//输入链表数据 { linklist head; head = new list; head-next = NULL; list *p,*q; q = head; int x; cinx; while(x!=00) { p = new list; p-data = x; p-next = NULL; q-next = p; q = p; cinx; } return head; } void sho

文档评论(0)

1974wangpeng + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档