数据结构课程设计_毕业论文.doc

  1. 1、本文档共30页,可阅读全部内容。
  2. 2、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 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)

店小二 + 关注
实名认证
内容提供者

包含各种材料

1亿VIP精品文档

相关文档