- 1、本文档共30页,可阅读全部内容。
- 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
数据结构课程设计_毕业论文
桂林航天工业学院
实验报告
系(部): 计算机科学与工程系
课程名称: 数据结构
专业班级: 计算机应用技术1班
学 号:
学生姓名:
完成日期: 2016年12月22日
一、 运行环境
操作系统:Windows10 64位操作系统
编译软件:Microsoft Visual C++ 6.0
处理器:Intel(R)Core(TM)2 CPU 6320 @ 1.86GHz 1.86GHz
安装内存(RAM):2.00GB
二、 算法设计的思想和设计分析及流程图
1.线性表的顺序存储
1.插入:
算法思想:查找到元素X需要插入到线性表L的位置i,将该位置i后面的元素后移,将要元素X插入到i位置,表长加1。
设计分析:先使用
if(L-last==MAXSIZE1-1)
提示空间满
else if(i1||iL-last+2)
提示位置错误
函数判断位置i在该线性表L中是否存在,若位置i正确再使用
for(j=L-last;j=i-1;j--)
{
L-data[j+1]=L-data[j];
}
使该位置i后面的数据元素后移,然后将数据元素插入到位置i,表长加1。
流程图:
2.删除:
算法思想:先判断线性表L是否存在数据元素i,然后在线性表L中删除序号为i的数据元素,删除后使序号为 i+1, i+2,..., n 的元素变为序号为 i, i+1,...,n-1,删除后新表长=原表长-1。
设计分析:先使用
if(i1 || iL-last+1)
提示数据元素不存在
判断元素i在线性表L中是否存在,若数据元素i存在再使用
for(j=i;j=L-last;j++)
{
L-data[j-1]=L-data[j];
}L-last--;
使数据元素i后面的数据元素前移,将数据元素i覆盖删除,然后表长减1。
流程图:
3.查找:
算法思想:调用函数查找数据元素i,如果其调用函数结果返回在线性表L中首次出现的值为i的那个元素的序号或地址,称为查找成功; 否则,在L中未找到值为x的数据元素,返回某特殊值表示查找失败。
设计分析:先使用
while(y=L-last L-data[y]!=x)
y++;
查找数据元素i在线性表L中的位置,如果查找失败则使用
if(yL-last)
return -1;
返回特殊值,否则使用
else return y+1;
返回该数据元素的地址。
流程图:
4.Main主函数:
算法思想:使用Do…while实现主函数的菜单界面,使用switch…case实现函数的调用。
设计分析:使用do…while做出主菜单,使用
scanf(%d,k);
getchar();
switch(k)
{
case 1: case 2: case 3: case 4: case 5:
}
实现函数的调用。
2. 线性表的链式存储
1.建表:
算法思想:使用头插入法建立单链表,该方法从一个空表开始,重复读入数据,生成新结点,将读入数据存放到新结点的数据域中,然后将新结点插入到当前链表的表头上,直到读入结束标志为止。
设计分析:
使用p=(LNode2*)malloc(sizeof(LNode2));开辟一个动态空间
使用
p-data=c;
p-next=head;
进行赋值和使指针后移,再用head=p;使head与p同指向。
流程图:
2.按序号查找:
算法思想:调用函数查找数据元素i,从链表的头指针出发,顺链域next逐个结点往下有哪些信誉好的足球投注网站,直到有哪些信誉好的足球投注网站到第i个结点为止。设单链表的长度为n,要查找表中第i个结点,仅当1≦i≦n时,i的值是合法的。但有时需要找头结点的位置,故我们将头结点看做是第0 个结点。
设计分析:
使用while(p-next ji)限定i的合法性
使用
p=p–next;
j++;
进行地址和指针后移,
再用
if (i==j) return p;
else return NULL;
返回查找结果。
流程图:
3.插入:
算法思想:插入运算是将值为x的新结点插入到表的第i个结点的位置上首先找到ai-1的存储位置p,然后生成一个数据域为x的新结点*q,并令结点*p的指针域指向新结点,新结点的指针域指向结点ai。
设计分析:
使用
p=Get_Lin
文档评论(0)