网站大量收购闲置独家精品文档,联系QQ:2885784924

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

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

  1. 1、本文档共18页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
实验一 线性表的基本操作及其应用 实验目的 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)

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

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

1亿VIP精品文档

相关文档