- 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、熟悉线性表的基本运算在两种存储结构上的实现,其中以熟悉链表的操作为侧重点。
二、实验内容
本次实验提供4个题目,每个题目都标有难度系数,*越多难度越大,学生可以根据自己的情况选做,其中题目一是必做题,其它选作!
?	题目一:单链表的基本操作(必做题  *)
   题目二:约瑟夫环(**)	
[问题描述]
实现带头结点的单链表的建立、求长度,取元素、修改元素、插入、删除等单链表的基本操作。
[基本要求]
(1)依次从键盘读入数据,建立带头结点的单链表;
    (2)输出单链表中的数据元素
(3)求单链表的长度;
(4)根据指定条件能够取元素和修改元素;
(5)实现在指定位置插入和删除元素的功能。 
 [测试数据]
由学生任意指定。
三、算法设计
1.算法思想:
主要设计了一个包含数据和指针域的结点。
        Data    *next
       主要思想:
插入:
     
删除:        
    
              
四、本函数包含八个模块
1.主函数int main() :初始化一个链表L,显示菜单,主要语句:switch语句,while语句,goto语句。
2.创建并输入链表数据linklist createlist(),在该函数中创建头结点,并输入结点上的数据。
伪代码:while(当x!=00)
{
p = new list;
					p-data = x;
					p-next = NULL;
					q-next = p;
					q = p;
}
3.显示链表数据void show(linklist L)
1)先判断是否是空表,再逐个寻找想要的元素。
2)主要代码:
while(p)
				{
					coutp-data\t;
					p = p-next;
				}
4.获取链表长度int getlength(linklist L)
1)先判断是否为空,再遍历链表,算出链表长度。
2)主要代码:
while(p)
				{
					p = p-next;
					length++;
				}
5.获取第i个元素int getdata(linklist L,int i)
1)当0ilength时,遍历链表,找到第i个元素。
2)主要代码:
while(pji)
		{
		j++;
		p = p-next;
}
6.改变链表数据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;
7.插入一个结点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;
8.删除一个结点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;
	h
                您可能关注的文档
最近下载
- 九年级语文上册期中测试卷.docx VIP
- 如何提高培智学校课堂教学的有效性-最新资料.pptx VIP
- 人教版小学六年级下册数学精品教学课件 第二单元 百分数(二) 2.2 成数.ppt VIP
- 1访谈记录不忘初心方得始终.pdf VIP
- 八年级期中考试质量分析报告.doc VIP
- 2023年郑州中牟事业单位笔试参考答案 - 副本.pdf VIP
- 机器人滚压包边DPCA F12 001-2008.doc VIP
- (完整版)水电、风电效益测算分析表.xls VIP
- 甘教版初中八年级信息技术第四章《多媒体作品的规划与设计》说课课件.ppt VIP
- 人教版小学六年级下册数学精品教学课件 第二单元 百分数(二) 2.1 折扣.ppt VIP
 原创力文档
原创力文档 
                        

文档评论(0)