数据结构双向链表学生成绩管理系统.docVIP

数据结构双向链表学生成绩管理系统.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
数据结构双向链表学生成绩管理系统

数学与计算机学院 实 验 报 告 课程名称 数据结构 课程代码 6014279 实验时间 年 月 日 指导单位 软件工程系 指导教师 周立章 学生姓名 吴超 年 级 10级 学 号 312010080611402 专 业 软件工程 实验成绩 实验名称 学生成绩管理系统 指导教师 周立章 实验类型 设计 实验学时 2+10 实验时间 实验目的和要求 (1)掌握线性表的顺序存储结构,在顺序存储结构基础上进行的插入、删除、查找等算法的思想和实现; (2)掌握线性表的链式存储结构。掌握线性表的链式存储结构的建立。在链表中插入、删除和查找算法的思想和算法实现。 (3)掌握线性表在顺序存储、链式存储结构的基础进行的各种应用。 (4)Student,每个学生包括学号、姓名、3门功课(课程名自己定义)、总分。 (2)建立双向循环链表:输入若干学生的信息(当输入学生的学号为0000时结束,要求自动计算总分),并按输入的顺序建立双向循环链表; (3)输出学生成绩信息:遍历双向循环链表,输出所有学生的完整信息到屏幕; (4)查找指定学号的学生信息。如果查找成功,输出所有学生信息,否则输出失败。 (5)插入学生信息:以队列的方式将新学生成绩信息插入到链表中; (6)删除学生信息:给出学生姓名,删除链表所有相同姓名的学生的信息(即姓名相同的结点); (7)修改学生信息:给出学生学号,修改该生的三门课程成绩信息; (8)按总分排序:在原来的双向循环链基础上按总分降序进行就地排列。即不能增加额外的空间开销; 实验前准备:完成上述(1)-(4)算法,并要求上机验证通过。 实验时完成(5)-(6)。 实验后,完成算法(7),(8) ,并要求上机验证通过。 实验解答: 1) 画出主函数的流程图 2)数据类型定义 (1)学生成绩信息结构体类型的定义 struct Student { int num; char name[20]; int math; int chinese; int english; int sum; struct Student *prior,*next; }; (2)双向链表结点的定义。是否将结点的数据类型定义为学生成绩信息结构体类型? 是的; 3)为了能够完成链表的各项操作,你给出的测试数据有哪些?主要用于测试哪些方面? 1 菜单函数测试: 2输入函数测试 3 查询函数测试 4 插入函数测试 5 删除函数测试 6 输出函数测试 7 修改函数测试 8 排序函数测试 实 验 报 告 4)你是否在实验前完成了算法(1)-(4)?如果完成了难点在哪儿?。如果没有完成,理由是什么? 答:是;难点在于双向循环链表的创建,在最后需要把最后一个结点指向头结点,否则会出现一系列问题; 5)建立双向循环链表,你采用的是后插法还是前插法?写出C++语言代码。 答:前插法,代码如下: void RDLink::Create() { Student *p,*s; int x; if((head=new Student)==NULL) {cout分配内存失败...endl;} head-prior=NULL; head-next=NULL; p=head; cout开始输入学生信息,输入时结束。endl; while(1) { if((s=new Student)==NULL) { cout分配内存失败...endl; } p-next=s; cout请输入学生的学号:; cinx; if(x==0000) break; else { s-num=x; cout请输入学生的姓名:; cins-name; cout请输入学生的数学成绩:; cins-math; cout请输入学生的语文成绩:; cins-chinese; cout请输入学生的英语成绩:; cins-english; s-sum=s-math+s-chinese+s-english; s-prior=p; s-next=NULL; p=s; } } s-next=head; head-prior=s; cout储存成功!endl; }Student *p=head-next; 用while(p!=head)来控制循环;循环一次p再指向下一结点:p=p-next; void RDLink::DispList() { Student *p=head-next; while (p!=head) { cout学生的学号:p-numendl; cout学生的姓名:p-nameendl; cout学生的数学成绩:p-mathendl; cout学生的语文成绩:p-chin

文档评论(0)

phltaotao + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档