- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、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 cout p- data \t; p p- next; 获取链表长度int getlength linklist L
先判断是否为空,再遍历链表,算出链表长度。
主要代码:
while p p p- next; length++; 获取第i个元素int getdata linklist L,int i
1)当0 i length时,遍历链表,找到第i个元素。
2)主要代码:
while pj i 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的实现
六、调试及感受
又是一次课设时,每次写程序总会遇到大大小小的毛病,就不断的调试调试,觉得写代码是需要很大的耐心,一直琢磨,一直分析,一直改,直至完美。可是当代码运行到自己想要的程度时,内心是那么的自豪,那么的傲娇,那么的兴奋,仿佛心长了翅膀似的,飞到高空翱翔去了,呵呵,感觉不错。不过,我希望自己下次不用再借鉴网上的代码,就能够自己迎仞有余,加油,我可以的!
并且谢谢老师的教导,老师您辛苦了!!!
七、源代码
#include
#include
#include
#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;
cin x;
while x! 00 p new list;
p- data x;
p- next NULL;
q- next p;
q p;
cin x; return head; void showlist linklist L //显示链表数据 if L- next NULL cout 该链表是空表! endl;
else list *p;
p L- next;
cout 该链表数据如下所示: endl;
while p cout p- data \t; p p- next; cout endl; int getlength lin
您可能关注的文档
最近下载
- Unit 1 Fun numbers and letters (说课稿)-2024-2025学年人教PEP版(一起)(2024)英语二年级上册.docx VIP
- 印刷成本核算方式.docx VIP
- 森林防火教学课件.ppt VIP
- 二级保密资格档案目录(24盒)优质材料.doc VIP
- 2025水利工程五大员专业题库(含答案).docx VIP
- 图书馆业务知识培训ppt课件.pptx VIP
- 传感器智能传感器与无线传感器网络技术.pptx VIP
- 中国共产党基层组织选举工作条例学习宣贯ppt课件.pptx VIP
- 游消费者行为学(第二版)孙九霞全套PPT课件.pptx
- 东芝 e-STUDIO 2000AC 2500AC 彩色复印机维修手册(拆卸安装篇).pdf VIP
文档评论(0)