- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C课设报告--学生成绩管理系统2
信息技术学院
计算机科学与技术专业
课程名称: 程序设计语言Ⅱ 课程设计题目: 学生成绩管理系统 院系: 信息技术学院 学号: 姓名: 指导教师: 职 称: 讲师
2011年7月 5日
目 录
1.任务要求 1
2.设计方案 1
3.设计内容 2
3.1.类设计图: 2
3.3 设计步骤: 3
3.4 调试: 3
3.5 结果: 4
3.6程序源代源 5
4.总结 5
5.参考文献 5
学生成绩管理系统
1.任务要求
⑴ 所设计的管理系统可实现对学生信息和每个学生成绩的管理。
⑵ 设计数据的存储方式,使得用户输入的数据能够保存到磁盘,并在下一次打开时可以读入已经存储的数据。当第一次使用无存盘数据时应自动创建磁盘数据记录文件。
⑶ 设计学生类,并通过类中包含的方法录入或从文件读入数据。
⑷在主界面中包括“输入学生成绩、显示统计数据、查找学生成绩、修改学生成绩、删除学生成绩、插入学生成绩、按平均分降序排列、显示全部学生成绩、退出本系统”等全部的功能。
2.设计方案
因为本系统是一个比较小的学生成绩管理系统,因此将程序的所有功能放在了一个文件中,使得方便对程序的管理。
总体思路如下流程图:
3.设计内容
3.1.类设计图:
【基本要求】
将学生定义成类Stu。
每个类中的私有成员变量需通过类中的友元函数获取值或设置值。
设计程序入口main()使用各类中的方法管理数据和信息。
设计读入文件和写入文件的代码。
3.2 设计步骤:
在main()函数中主要是通过“switch(menu())”选择判断来调用相关功能模块。系统的运行是在一个循环里进行的,只有在主界面并选择“退出本系统”时,才会跳出循环,并退出程序。
在主界面中包括“输入学生成绩 显示统计数据 查找学生成绩 修改学生成绩 删除学生成绩 插入学生成绩 按平均分降序排列 显示全部学生成绩 退出本系统”等全部的功能,之所以设计这么一个主界面,一是因为能使用户对程序操作的流程更加清楚简明,二是保证了用户同时只能对一个文件进行操作的系统要求,保证了系统不会发生打开文件紊乱或者出现致命错误。每个函数的具体功能:
1)主函数main():定义学生结构体数组,调用录入、统计等函数对成绩表进行处理;
2)录入函数Input():输入班级到政治课成绩;
3)统计函数Tongji():计算平均成绩;
4)查询函数Lookup():查询指定学号学生成绩记录;
5)修改函数Xiugai():修改指定学号学生成绩记录;
6)删除函数Delete():删除指定学号学生记录;
7)输出函数OutputAll():输出班级所有学生成绩记录;
8) 排序函数Sort():按平均分对学生成绩记录项进行降序排序;
9)插入函数Insert():按平均分顺序插入新记录。
3.3 调试:
调试是整个程序编写过程中十分重要也是很困难的一部分,在这个过程中用了不少的时间进行程序的调试,在调试过程中遇到的相关问题如下:
一、语法错误
1、语句的最后忘记了加上“;”,使程序发生错误。
2、把“”与“”写反,以及字符与字符串的操作问题,这些是比较简单的错误,很容易分辨出来,并改正之。
3、函数的返回值问题,也是比较容易找出并解决的问题。
二、逻辑错误
1、文件的写入与读出,刚开始对文件的操作不太明白,一致不能很好的操作文件,其中最大的问题是对已存在的文件读取问题,通过“显示全部学生成绩” 将数据从文件中读取,可是在使用过程中总是出现读出错误,出现乱码。
2、内存的分配问题,这也是困惑了我好久的问题。对于我们初学者来说对内存的分配和释放问题是比较抽象和模糊的难题,本来使用链表的方式存储数据,然而待到排序时出现了交换数据困难的问题,以及分配空间繁琐释放空间不及时的问题,造成空间浪费使得程序运行效率低的问题。因此最后采用了顺序存储记录的方式,这样就能改变前述问题。
整个调试过程中主要是这么几个问题,其余的是一些小问题,很容易的就调试出来了。
3.4 结果:
3.5程序源代源
#includeiostream.h
#includefstream.h
#includestdlib.h
#includestring.h
#includestdio.h
class Stu //构建学生类
{
public:
friend void Input(Stu stud[]) ;//能够访问类的所有成员的函数
friend void Tongji(Stu stud[]);
friend void Lookup(Stu stud[]) ;
friend void Change(Stu stud[]) ;
friend void Delete(Stu stud[
文档评论(0)