学生成绩管理系统-综合程序设计.doc
《学生成绩管理系统-综合程序设计.doc》由会员分享,可在线阅读,更多相关《学生成绩管理系统-综合程序设计.doc(10页珍藏版)》请在咨信网上搜索。
实验16 综合程序设计 1.实验学时 2学时 2.实验目的 (1)熟练掌握函数的定义和使用; (2)熟练掌握结构体类型数据的概念和使用; (3)熟练掌握文件的操作方式以及常用函数; (4)掌握用模块化分析与设计方法解决实际问题. 3。实验设备 PC计算机,配置Win7操作系统,Word2010,Eclipse+minGW 4.实验内容及步骤 设计一个学生成绩管理系统,实现添加记录、显示记录、修改记录、删除记录、查找记录、排序记录及退出系统等功能。 添加记录 显示记录 修改记录 删除记录 查找记录 排序记录 退出系统 学生成绩管理系统 菜单选择 图16—1 4.1需求分析 根据题目要求,学生管理系统需要实现添加记录、显示记录、修改记录、删除记录、查找记录、排序记录及退出系统等7项功能。图16-1显示学生成绩管理系统的所有需实现的功能模块及彼此之间的关联关系,该图的每一个功能都会对应一个界面。该系统首先会向用户展现一个菜单选择界面,用户可以根据菜单界面的提示,选择不同功能进入子界面。 4.1.1添加记录 本功能用于添加学生的信息,当用户在功能菜单中选择数字1时,会进入添加记录模块,提示用户输入学生的学号、姓名、数学成绩、语文成绩.当用户输入完毕后,会提示用户是否继续添加,Y表示继续,N表示返回。需要注意:在添加学号时不能重复,如果输入重复的学号就会提示此学号存在. 4.1。2显示记录 本功能用于显示已存入的学生信息,当用户在功能菜单中选择数字2时,会进入显示记录模块,并向控制台输出录入的所有学生的学号、姓名、数学成绩、语文成绩和成绩总和. 4。1.3修改记录 本功能用于修改学生信息,当用户在功能菜单中选择数字3时,会进入修改记录模块.输入要修改的学生姓名,当用户输入了已录入的学生姓名后,如果学生信息存在即可修改除学号以外的其他信息,否则输出该学生不存在. 4.1。4删除记录 本功能用于删除已录入的学生信息,当用户在功能菜单中选择数字4时,会进入删除记录模块。对学生学号进行判断,如果学号存在即可删除该生的所有信息,否则输出没有找到该生的记录。 4.1。5查找记录 本功能用于查找某个学生信息,当用户在功能菜单中选择数字5时,会进入查找记录模块.在该模块中输入查找的学生姓名,如果该学生存在则输出该生的全部信息,否则输出没找到该生的记录. 4。1。6排序记录 本功能用于对总成绩进行排序,当用户在功能菜单中选择数字6时,会进入排序记录模块.该模块会输出所有学生的信息,并按总成绩由高到低进行排序. 4。1.7退出系统 本功能用于退出系统,当用户在功能菜单中选择数字0时,即可退出系统。 4。2数据设计 根据系统分析,需要确定项目中的数据.由于学生成绩管理系统中多次涉及学生信息及其成绩信息的操作,因此根据学生成绩管理系统的需求,设计学生的数据如表16—1所示 表16-1 学生数据 变量声明 功能描述 int id 存储学生学号 char name[8] 学生姓名 intchinese 语文成绩 int math 数学成绩 int sum 总成绩 由于学生的数据各不相同,为便于统一管理,可以使用结构体类型来声明。 在项目开发时,除根据需求对项目中的数据进行设计外,还需要规划项目中需要定义的函数.表16—2描述了本项目所需的函数及其功能描述 表16—2功能函数 函数声明 功能描述 void menu() 显示功能菜单 void add(struct student stu[]) 添加学生信息 void show(struct student stu[],inti) 显示某个学生信息 voidshowAll(struct student stu[]) 显示所有学生信息 void modify(struct student stu[]) 修改某个学生信息 void del(struct student stu[]) 删除某个学生信息 void search(struct student stu[]) 查询某个学生信息 void sort(struct student stu[]) 对学生成绩进行排序 至此,项目的分析与初步设计已完成,后面就是需要对每一部分用程序进行实现,请同学们完成. 实验源程序如下:—_- 综合程序设计: /* * student.c * * Created on: 2015年12月29日 * Author: PC */ #include”student。h” void menu() { system(”cls”); printf("\n”); setvbuf(stdout,NULL,_IONBF,0); printf("\t\t——-—-—-——————-学生成绩管理系统—-----———-—--—\n”); printf("\t\t|\t\t 1 添加记录 |\n"); printf("\t\t|\t\t 2显示记录 |\n”); printf("\t\t|\t\t 3 修改记录 |\n"); printf("\t\t|\t\t 4 删除记录 |\n”); printf(”\t\t|\t\t 5 查找记录 |\n”); printf(”\t\t|\t\t 6 排序记录 |\n”); printf("\t\t|\t\t 0 退出系统 |\n”); printf(”——-—-———-——-——----—-—-——--—-—--—--—————--—-—\n"); printf(”\t\t请选择(0-6): "); } void add(struct student stu[]) { inti,id=0; char quit; do { printf("学号:"); scanf(”%d”,&id); for(i=0;i〈n;i++) { if(id==stu[i]。id) { printf(”此学号已存在! \n"); return; } } stu[i].id=id; printf(”请输入姓名: ”); scanf(”%s",stu[i]。name); printf(”请输入语文成绩: ”); scanf(”%d”,&stu[i]。chinese); printf(”请输入数学成绩 : ”); scanf(”%d”,&stu[i].math); stu[i].sum=stu[i]。chinese + stu[i]。math; n++; printf(”是否继续添加?(Y/N)?”); scanf(”\t%c",&quit); }while(quit!=’n’ && quit != ’N’); } void show(struct student stu[],inti) { printf("%—10d”,stu[i]。id); printf(”%-10s",stu[i]。name); printf(”%—10d”,stu[i].chinese); printf("%—10d”,stu[i].math); printf(”%—10d”,stu[i]。sum); } voidshowall(struct student stu[]) { inti; HH; for(i=0;i〈n;i++) { show(stu,i); printf(”\n"); } } void modify(struct student stu[]) { char name[8],ch; inti; printf(”修改学生记录\n"); printf(”请输入学生的姓名: ”); scanf(”%s”,name); for(i=1;i<n;i++) { if(strcmp(stu[i]。name,name)==0) { getchar(); printf(”找到学生的记录,如下所示: ”); HH; show(stu,i); printf("是否修改?(Y/N)?”); scanf(”%c”,&ch); if(ch==’y' || ch=='Y’) { getchar(); printf(”请输入姓名: ”); scanf(”%s”,stu[i]。name); printf(”请输入语文成绩: ”); scanf("%d”,&stu[i]。chinese); printf("请输入数学成绩: ”); scanf(”%d”,&stu[i].math); stu[i]。sum = stu[i]。chinese + stu[i]。math; printf(”修改完毕\n"); } return; } } printf("没找到该学生的记录\n”); } void del(struct student stu[]) { intid,i; charch; printf("删除学生的记录\n”); printf(”请输入学号: ”); scanf("%d”,&id); for(i=0;i〈n;i++) { if(id==stu[i]。id) { getchar(); printf("找到学生的记录,如下所示: \n”); HH; show(stu,i); printf(”是否删除?(Y/N)?\n”); scanf("%c",&ch); if(ch==’y' || ch=='Y’) { for(;i〈n;i++) { stu[i]=stu[i+1]; } n-—; printf(”删除成功”); } } return; } } void search(struct student stu[]) { char name [8]; inti; printf("查找学生的记录\n”); printf(”请输入学生的姓名: "); scanf(”%s",name); for(i=0;i<n;i++) { if(strcmp(name,stu[i].name)==0) { printf("找到学生的记录,如下所示: ”); HH; show(stu,i); return; } } } void sort(struct student stu[]) { inti,j; struct student t; printf(”按学生成绩进行排序\n"); for(i=0;i〈n—1;i++) { for(j=i+1;j<n;j++) { if(stu[i]。sum 〈 stu[j]。sum) { t=stu[i]; stu[i]=stu[j]; stu[j]=t; } } } printf(”排序的结果如下: \n"); showall(stu); } /* * stumanagement.c * * Created on: 2015年12月29日 * Author: PC */ #include〈stdio。h> #include”student。h” int main() { struct student stu[50]; intselect,quit=0; while(1) { menu(); scanf(”%d”,&select); switch(select) { case 1: add(stu); break; case 2: showall(stu); break; case 3: modify(stu); break; case 4: del(stu); break; case 5: search(stu); break; case 6: sort(stu); break; case 0: quit=1; break; default: printf("请输入0—6之间的数字"); break; } if(quit==1) break; printf("按任意键返回主菜单!\n"); getchar(); getchar(); } printf(”程序结束!\n”); return 0; } /* * student。h * * Created on: 2015年12月29日 * Author: PC */ #ifndef STUDENT_H_ #define STUDENT_H_ #include<stdio。h〉 #include<string.h〉 #include<stdlib。h〉 #define HH printf(”%—10s%-10s%—10s%—10s%—10s\n",”学号”,”姓名”,”语文",”数学",”总分”); struct student{ int id; char name[8]; intchinese; int math; int sum; }; staticint n; void menu(); void add(struct student stu[]); void show(struct student stu[],inti); voidshowall(struct student stu[]); void modify(struct student stu[]); void del(struct student stu[]); void search(struct student stu[]); void sort(struct student stu[]); #endif /* STUDENT_H_ */ 第 10页 /共 10页- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 学生 成绩管理系统 综合 程序设计
咨信网温馨提示:
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
1、咨信平台为文档C2C交易模式,即用户上传的文档直接被用户下载,收益归上传人(含作者)所有;本站仅是提供信息存储空间和展示预览,仅对用户上传内容的表现方式做保护处理,对上载内容不做任何修改或编辑。所展示的作品文档包括内容和图片全部来源于网络用户和作者上传投稿,我们不确定上传用户享有完全著作权,根据《信息网络传播权保护条例》,如果侵犯了您的版权、权益或隐私,请联系我们,核实后会尽快下架及时删除,并可随时和客服了解处理情况,尊重保护知识产权我们共同努力。
2、文档的总页数、文档格式和文档大小以系统显示为准(内容中显示的页数不一定正确),网站客服只以系统显示的页数、文件格式、文档大小作为仲裁依据,个别因单元格分列造成显示页码不一将协商解决,平台无法对文档的真实性、完整性、权威性、准确性、专业性及其观点立场做任何保证或承诺,下载前须认真查看,确认无误后再购买,务必慎重购买;若有违法违纪将进行移交司法处理,若涉侵权平台将进行基本处罚并下架。
3、本站所有内容均由用户上传,付费前请自行鉴别,如您付费,意味着您已接受本站规则且自行承担风险,本站不进行额外附加服务,虚拟产品一经售出概不退款(未进行购买下载可退充值款),文档一经付费(服务费)、不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
4、如你看到网页展示的文档有www.zixin.com.cn水印,是因预览和防盗链等技术需要对页面进行转换压缩成图而已,我们并不对上传的文档进行任何编辑或修改,文档下载后都不会有水印标识(原文档上传前个别存留的除外),下载后原文更清晰;试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓;PPT和DOC文档可被视为“模板”,允许上传人保留章节、目录结构的情况下删减部份的内容;PDF文档不管是原文档转换或图片扫描而得,本站不作要求视为允许,下载前自行私信或留言给上传者【快乐****生活】。
5、本文档所展示的图片、画像、字体、音乐的版权可能需版权方额外授权,请谨慎使用;网站提供的党政主题相关内容(国旗、国徽、党徽--等)目的在于配合国家政策宣传,仅限个人学习分享使用,禁止用于任何广告和商用目的。
6、文档遇到问题,请及时私信或留言给本站上传会员【快乐****生活】,需本站解决可联系【 微信客服】、【 QQ客服】,若有其他问题请点击或扫码反馈【 服务填表】;文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“【 版权申诉】”(推荐),意见反馈和侵权处理邮箱:1219186828@qq.com;也可以拔打客服电话:4008-655-100;投诉/维权电话:4009-655-100。
关于本文