数据结构课程设计题目02599.docx
《数据结构课程设计题目02599.docx》由会员分享,可在线阅读,更多相关《数据结构课程设计题目02599.docx(163页珍藏版)》请在课桌文档上搜索。
1、数据结构实践教程目录第一部分基础篇第一章线性表1.1学生成绩管理1.1.1项目简介1.1.2设计思路1.1.3数据结构1.1.4程序清单1.1.5运行结果1.2考试报名管理1.2.1项目简介1.2.2设计思路1.2.3数据结构1.24程序清单1.2.5运行结果1.3约瑟夫生者死者游戏1.3.1项目简介1.3.2设计思路1.3.3数据结构1.3.4程序清单1.3.5运行结果1.4约瑟夫双向生死游戏1.4.1项目简介1.4.2设计思路143数据结构1.4.4程序清单1.4.5运行结果第二章栈和队列2.1迷宫旅行游戏2.1.1项目简介2.1.2知识要点2.1.3设计思路2.1.4程序清单2.1.5运
2、行结果2.2八皇后问题2.1.1项目简介2.1.2知识要点2.1.3设计思路2.1.4程序清单2.1.5运行结果2.3停车场的停车管理2.1.12.1.22.1.32.1.42.1.5第三章串、项目简介知识要点 设计思路程序清单 运行结果数组和广义表3.1.13.1.23.133.1.43.1.5单词检索统计程序项目简介设计思路数据结构程序清单运行结果3.2Internet网络通路管理3.2.1项目简介3.2.2设计思路3.2.3数据结构3.2.4程序清单3.2.5运行结果第四章树和二又树4.1家谱管理4.1.1项目简介4.1.2设计思路4.1.3数据结构4.1.4程序清单4.1.5运行结果4
3、.2表达式求值问题4.2.1项目简介4.2.2设计思路4.2.3数据结构4.2.4程序清单4.2.5运行结果4.4图像压缩编码优化4.4.1项目简介4.4.2设计思路4.4.3数据结构4.4.4程序清单4.4.5运行结果第五章图5.1公交路线管理5.1.1项目简介5.1.2设计思路5.1.3数据结构5.1.4程序清单5.1.5运行结果5.2导航最箱i路径查询5.2.1项目简介5.2.2设计思路5.2.3数据结构5.2.4程序清单5.2.5运行结果5.4电网建设造价计算5.4.1项目简介5.4.2设计思路5.4.3数据结构5.4.4程序清单5.4.5运行结果5.4软件工程进度规划5.4.1项目简
4、介5.4.2设计思路5.4.3数据结构544程序清单5.4.5运行结果第二部分综合篇1.1景区旅游信息管理系统1.1.1项目需求1.1.2知识要点1.1.3设计流程1.1.4程序清单1.1.5运行测试第一部分基础篇第一章线性表线性表是数据结构中最简单、最常用的一种线性结构,也是学习数据结构全部内容的基础,其掌握的好坏直接影响着后继知识的学习。本章通过四个模拟项目来学习线性表的顺序和链式存储结构,首先通过使用有关数组的操作实现学生成绩管理,其次通过使用有关线性链表的操作实现考试报名管理,然后通过使用循环链表的操作实现约瑟夫生者死者游戏。1.1学生成绩管理1.1.1项目简介学生成绩管理是学校教务部
5、门日常工作的重要组成部分,其处理信息量很大。本项目是对学生成绩管理的简单模拟,用菜单选择方式完成下列功能:输入学生数据;输出学生数据;学生数据查询;添加学生数据:修改学生数据;删除学生数据。1.1.2设计思路本项目的实质是完成对学生成绩信息的建立、查找、插入、修改、删除等功能,可以首先定义项目的数据结构,然后将每个功能写成一个函数来完成对数据的操作,最后完成主函数以验证各个函数功能并得出运行结果。1.1.3数据结构本项日的数据是一组学生的成绩信息,每条学生的成绩信息由学号、姓名和成绩组成,这组学生的成绩信息具有相同特性,属于同一数据对象,相邻数据元素之间存在序偶关系。由此可以看出,这些数据具有
6、线性表中数据元素的性质,所以该系统的数据采用线性表来存储。顺序表是线性表的顺序存储结构,是指用一组连续的内存单元依次存放线性表的数据元素。在顺序存储结构下,逻辑关系相邻的两个元素在物理位置上也相邻,这是顺序表的特点。本项目可以采用顺序表的线性表顺序存储结构。若一个数据元素仅占一个存储单元,则其存储方式参见图1-1。从图1-1中可见,第i个数据元素的地址为1.oc(ai)=loc(al)+(i-l)假设线性表中每个元素占用k个存储单元,那么在顺序表中,线性表的第i个元素的存储位置与第1个元素的存储位置的关系是1.oc(ai)=loc(a)+(i-l)*k这里LOC(ai)是第i个元素的存储位置,
7、loc(al)是第1个元素的存储位置,也称为线性表的基址。显然,顺序表便于进行随机访问,故线性表的顺序存储结构是一种随机存储结构。顺序表适宜于做查找这样的静态操作;顺序存储的优点是存储密度大,存储空间利用率高。缺点是插入或删除元素时不方便。由于C语言的数组类型也有随机存储的特点,一维数组的机内表示就是顺序结构。因此,可用C语言的一维数组实现线性表的顺序存储。数组实现线性表的顺序存储的优点是可以随机存取表中任一元素0(1),存储空间使用紧凑:缺点是在插入,删除某一元素时,需要移动大量元素O(n),预先分配空间需按最大空间分配,利用不充分,表容量难以扩充。用结构体类型定义每个学生数据,故该数组中的
8、每个数据的结构可描述为:typedefstructSTUcharstuno10;学号charname10;姓名oatscore;成绩ElemType:1.1.4程序清单#include#include#include#include#defineMaxListSize20#defineEQUAL1typedefstructSTUcharstuno10;charname10;floatscore;JElemType;classListprivate:/线性表的数组表示ElemTypeelemMaxListSize;intlength;intMaxSize;public:/输入学生数据voidin
9、it(List*L,intms);删除所有学生数据voidDestroyList(List&L)free(&L);)将顺序表置为空表voidCletrList()Iength=O;判断顺序表是否为空表boolListEmptyOreturnIength=O;判断顺序表是否为满boolListFullOreturnIength=MaxSize;删除某个学生数据boolListDeleteCinuEIemType&e);遍历顺序表voidListTraverseO;返回顺序表的长度intListLengthO;学生数据查询voidGetElem(intElemType*);/修改学生数据blUpd
10、atcList(ElcmType&e,ElcmType);添加学生数据boolListInserUinLElemType&);对学生数据按升序或降序输出voidprintlist(int);:voidList:init(List*LJntms)*L=(List*)malloc(sizeof(List);(*L)-length=0;(*L)-MaxSize=ms;intListzzListLengthOreturnlength;boolList:ListDelete(intmark,ElemType&e)intij;if(ListEmpty()returnfalse;if(mark0)删除表头元
11、素e=elem0;for(i=l;ilength;i+)elemi-l=elemijelse删除表尾元素if(mark0)e=elemlength-l;else删除值为e的元素for(i=O;i=length)returnfalse;elsee=elemi;for(j=i+lylengthy+)elemj-l=elcmj;length-;returntrue;IvoidList:ListTraverse()for(inti=O;ivlength;i+)coutsetw(8)elemi.name;coutsetw(IO)elemi.stuno;coutsetw(9)elemil.age;cout
12、setw(8)elemi.scorenamete2-namc)完整版学习资料分享-returnfalse;if(strcmp(e1-stuno,e2-stuno)returnfalse;if(el-age!=e2-age)returnfalse;if(el-score!=e2-score)returnfalse;returntrue;boolList:Less_EqualList(ElemType*el,ElemType*e2)if(strcmp(el-name,e2-name)=0)returntrue;elsereturnfalse;boolList:LocateE)em(ElemType
13、e,inttype)i11ti;switch(type)caseEQUAL:for(i=O;ilength;i+)if(EqualList(&elemi,&e)returntrue;break;defaulcbreak;returnfalse;I修改学生数据boolList:UpdateList(ElemTypeAe,ElemTypeel)for(inti=O;ilength;i+)if(strcmp(elemiJ.namete.name)=O)(elemil=eHrelurntrue;returnfalse;boolList:ListInsert(inti,ElemType&e)ElcmTy
14、pe*p,*q;if(ilength+l)returnfalse;q=&elemi-l;for(p=q;p)-完整版学习资料分享一*(pl)=*p;*q=e;+length;returntrue;对学生成绩按升序或降序输出voidList:printlist(intmark)int*b=newintlength;inti,k;cout,r姓名学号成绩、f;if(mark!=0)for(i=0;ilength;i+)bi=i;for(i=0;ilength;i+)k=i;fbr(intj=i+lylengthy+)if(mark=1&elembj.scoreelembk.score)k.;if(
15、mark=-l&elem|b|kl|.scoreelemb|j.score)k=j;if(k!=i)intx=bi;bi=bk;bk=x;)for(inti=O;ilength;i+)(coutsetw(8)elembij.name;coutsetw(10)elembi.stuno;coutsetw(9)elembi.age;coutsetw(8)elembli.scoreendl;)elsefor(i=O;ilength;i+)coutsetw(8)elemij.name;coutsetw(10)elemi.stuno;coutsetw(9)elemi.age;coutsetw(8)elem
16、i.scoreendl;)voidmain()cout*Lc;intk;COUtinit(La,4);StrCPy(eLnamcJstu);strcpy(e1.stunoj,1(X)OOl);el.age=22;el.score=88;1.a-ListInsert(1,e1);strcy(e2.nanestu2n);stcpy(e2.Stuno/1100002,);e2.age=21;e2.score=79;1.a-ListInsert(2,e2);strcpy(e3jaestu3);strcy(e3.Stuno/11(X1003,);e3.age=19;e3.score=87;1.a-Lis
17、tlnsert(3te3);1.a-Aprintlist(O);COUt表Lad,ListLength()init(ListInsert(1,e4);strcpy(e5.name,bobjin);strcy(e5.stuno11(XK)02,);e5.age=23;e5.score=69;1.b-Listlnsert(2+e5);strcpy(e6.name,stu,);strcpy(e6.Stuno,1100OO);eGage=22;e6.score=88;1.b-ListInsert(3,e6);Lb-printlist(O);CoUt表LbjzListLength()ListDelete
18、(-1,e6);if(k=O)cout”删除失败!n;elseCOUtVV”删除成功!n;COUtprintlist(O);cin.get();CoUtprintlist(1);cin.get();COUlVV按成绩降序输出表Lcnr,;1.c-printlist(-1);cin.get();1.1.5运行结果首先建立学生信息管理,输出结果为:姓名学号成绩Stul100OOl80Stu210000291Stu310000356其次查询学号为I(X)OO2的学生的成绩,输出结果为:91再次调用插入函数,插入Stu4成功!输入结果为:姓名学号成绩Stul10000180Stu210000291St
19、u310000356Stu410000475最后删除Stu2成果!输出结果为姓名学号成绩Stul10000180Stu310000356Stu410000475查询不及格的学生,输出结果为:Stu3100003561.2考试报名管理1.2,1项目简介考试报名工作给各高校报名工作带来了新的挑战,给教务管理部门增加了很大的工作量,报名数据手工录入既费时又会不可避免地出现错误,同时也给不少学生以可乘之机。本项目是对考试报名管理的简单模拟,用菜单选择方式完成下列功能:输入考生信息.:输出考生信息:查询考生信息:添加考生信息;修改考生信息;删除考生信息。1.2.2设计思路本项日的实质是完成对考生信息的建
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 数据结构 课程设计 题目 02599
链接地址:https://www.desk33.com/p-822543.html