下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、实验报告学 生 学 籍 管 理 系 统 专业: 信息管理与信息系统 班级:学号: 姓名:学生学籍管理系统一、实验要求: 一个班级有若干名学生 不超过 10 名),共有三门课程,分别是语文、数 学、英语,要求编写一个成绩的管理系统,每个学生要求有学号、姓名、性 别、三门课的成绩以及平均成绩,要实现从键盘上输入学号 必须为数字)、姓 名、性别、三门课程的成绩,并求每一位学生的平均成绩 即每一行的平均值)、每一位学生的最高分 每一行的最大值),求每一门课程的平均分 即每 一列的平均值)、每一门课的最高分 即每一列的最大值),并输出全部结果。 根据学生的平均成绩进行排序,对语文、数学、英语成绩进行排序
2、,并输出排 序结果,排序必须使用冒泡排序法。并且具有如下的菜单:学生学籍管理系统* MENU *1、Enter new data2、Browse all3、Search by num4、Order by average5、Exit用户可以根据菜单来选择操作,菜单的含义如下:1、Enter new data 输 入新数据2、Browse al浏览所有数据3、Search by num 根 据学号查询学生信息4、Order by average 根 据平均成绩排序5、Exit退出系统实验步骤:二、实验目的1、了解和熟悉 Visual C+ 软件编程开发环境2、熟练掌握结构化程序设计的步骤和模块化设
3、计方法3、熟练掌握 C 语言数据类型,熟记字符型数据和整形数据的定义和使用4、熟练掌握用 while 语句、 dowhile 语句和 for 语句实现循环结构程序设 计的方法5、掌握一维数组、二维数组的定义、赋值和输入输出的方法6、掌握与数组有关的算法 特别是排序算法,熟练掌握冒泡排序法)7、熟悉函数的定义、声明方法及全局变量和局部变量的概念与用法,掌握 函数的调用方法8、掌握结构体类型变量的定义和使用及结构体类型数组的概念和应用三、实验步骤1、分析设计题目: 根据题目要求,可以使用结构体数组来存储学生的信息,包括学号、姓 名、性别、各科成绩、平均成绩五个成员,分别使用字符数组、整型数 组、浮
4、点型变量来表示。在主函数之外,分别编写菜单函数menu(、输入函数 enter(、浏览函数 browse(、查找函数 search(、排序函数 order(等 函数,通过主函数调用 menu来实现。2、实验流程图:结束3、实验模块:输入模块、浏览模块、查找模块、排序模块、退出系统4、程序的调试与测试:所谓程序调试是指对程序的查错与排错。在编写完一个源程序之后,不 要立即进行编译,而应对程序进行全面的人工检查一遍,检查无误后,可 以开始进行程序调试。由编译系统进行检查、发现错误,根据编译系统提 示的错误类型和警告及出现的位置,我们可以定位到错误地点进行修改, 然后再编译,如此反复进行,直至不再出
5、现错误位置,最后才进行程序的 连接于运行。调试完以后,下一步就是对程序进行测试,运行程序,向程 序中输入数据,根据输出结果是否正确 <是否符合自己的想法)来判断程序 是否正确,如果不正确或不符合自己的目的,就需要对程序进行修改。然 后再调试,再测试,直至结果无误或符合要求后,测试才算结束,此时, 程序才算是满足题目要求的正确程序。5、运行结果:<1)运行结果界面如下:<3)选择 2 号菜单,浏览所有信息,运行结果如下:<2)选择 1 号菜单,输入 10 名同学信息,运行结果如下:<4)选择 3 号菜单,按学号查找学生信息,例如查找学号为 03 的同德信 息,输入格
6、式如下 :<5)查询学号为 03 的同学的信息运行结果如下:<6)选择 4 号菜单,进入学生成绩排序功能菜单,运行结果如下:<7)选择 1 号功能菜单,按每位学生的平均成绩从小到大排序,运行结 果如下:<8)选择 2 号功能菜单,按语文成绩从小到大排序,运行结果如下:<9)选择 3 号功能菜单,按数学成绩从小到大排序,运行结果如下:四、实验体会通过完成这个综合的设计实例,从中我熟悉了Visual C+开发环境,熟练掌握了在 Visual C+软件环境下编写和调试程序。通过对程序的调试,我从学到了许多知识,根据编译时系统提供的错误提示,我能很快地找到错误并排除这些错
7、误,是程序能正确运行。通过这个环节的不断练习,我积累了丰富的经验,为以后编程和调试程序奠定了基础。通过运行程序,对程序不断改动,仔细观察和分析所出现的情况,锻炼了我对立思考的能力,而且增强了我对 C 语<10)选择 4 号功能菜单,按英语成绩从小到大排序,运行结果如下:<12)选择 5 号菜单,退出系统,按任意键结束程序,运行结果如下:言应用这门课程的兴趣。 五、源程序#include<stdio.h> /*头文件 */ #include<string.h>#include<stdlib.h> #define N 100#define M 3ty
8、pedef struct student /*定义学生结构体 */char num11。char name20。char scoreM 。float Max_course。STU。STU stuN,stu_ChineseN,stu_MathN,stu_EnglishN 。 int MaxM 。float ave_Chinese。float ave_Math。float ave_E n。/* 实际存储的学生个数 */void no_input(int i,int n>/*i 表示第 i 个的学生信息, n 表示比较到第 n 个学 生*/
9、 int j,k,w1 。do w1=0。printf("NO.:"> 。 scanf("%s",&stui.num> 。for(j=0 。stui.numj!='0' 。j+>/* 学号输入函数,作了严格规定 */ if(stui.numj<'0'|stui.numj>'9'>/* 判断学号是否为数字 */ puts("Input error! Only be made up of (0-9>.Please reinput!n">
10、 。w1=1。 break。 if(w1!=1> for(k=0。k<n。k+>/* 比较到第 n 个学生*/ if(k!=i&&strcmp(stuk.num,stui.num>=0> puts("This record is exist.Pleasereinput!n"> 。w1=1。 break。 while(w1=1> 。void input(int i>/* 输入一个记录函数 */ int j,sum 。 no_input(i,i> 。/* 调用学号输入函数 */ printf("na
11、me:"> 。 scanf("%s",&>。 printf("sex:"> 。 scanf("%s",&stui.sex> 。 for(j=0 。j<M 。j+> printf("score %d:",j+1> 。 scanf("%d",&stui.scorej> 。for(sum=0,j=0。j<M 。 j+> sum+=stui.scorej 。stui.ave=sum*1.0/M
12、 。 /* 每一行的平均值,即每位同学的三门课总的平 均分 */void menu(>。/* 函数声明 */void enter(>/*输入模块 */int i,j,f 。system("CLS">。/*清屏*/printf("How many students(0-%d>?:",N> 。/* 要输入的记录个数 */ scanf("%d",&n> 。printf("nEnter data nownn"> 。 for(i=0 。i<n 。i+> print
13、f("nInput %dth student record.n",i+1> 。 input(i> 。 /* 调用输入函数 */for(i=0 。 i<n。 i+>/* 求每一行的最大值,即求每一位学生的三门课中的 最高分 */ stui.Max_course=stui.score0 。 for(j=1 。j<M 。 j+> if(stui.Max_course<stui.scorej>stui.Max_course=stui.scorej 。for(i=0 。 i<n 。 i+>/* 把 输 入 的 信 息 分 别
14、 复 制 到 stu_ChineseN,stu_MathN,stu_EnglishN 中*/ stu_Chinesei=stui。 stu_Mathi=stui 。 stu_Englishi=stui 。printf(" 返回主菜单请按数字 0n">。do scanf("%d",&f> 。 if(f=0> menu(>。 break。else printf("输入有误,请重新输入 :"> 。while(f!=0> 。void printf_one(int i>/* 显示一个记录函数 *
15、/int j 。 printf("%3s :%3s",stui.num,> 。 for(j=0 。j<M 。j+>printf("%10d",stui.scorej> 。 printf("%10.2f",stui.ave> 。printf("%9dn",stui.Max_course> 。void browse(> /* 浏览模块 */int i,j,f,k=0 。 system("CLS">。/*清屏*/ for(i=0 。i&
16、lt;n 。i+>/* 求第一列的平均值,即求语文平均成绩 */ k=k+stui.score0 。 ave_Chinese=(k*1.0>/n。 k=0。for(i=0。i<n。i+>/* 求第二列的平均值,即求数学平均成绩 */ k=k+stui.score1 。ave_Math=(k*1.0>/n。 k=0。 for(i=0。i<n。i+>/* 求第三列的平均值,即求英语平均成绩 */ k=k+stui.score2 。 ave_English=(k*1.0>/n。Max0=stu0.score0 。/*第一列的最大值,即语文成绩最高分 *
17、/ for(i=1 。i<n 。i+> if(Max0<stui.score0> Max0=stui.score0 。Max1=stu0.score1 。/*第二列的最大值,即数学成绩最高分 */ for(i=1 。i<n 。i+> if(Max1<stui.score1> Max1=stui.score1 。Max2=stu0.score2 。/*第三列的最大值,即英语成绩最高分 */ for(i=1 。i<n 。i+> if(Max2<stui.score2> Max2=stui.score2 。puts("
18、n"> 。printf("n NO : name Chinese Math English average Max_coursen">。for(i=0 。i<n 。i+> if(i!=0>&&(i%10=0>>/* 目的是分屏显示 */ printf("nnPass any key to continue.">。 getchar(>。puts("nn">。 printf_one(i> 。/* 调用显示一个记录函数 */ puts("n
19、"> 。printf(" ave_Chinese ave_Math ave_Englishn">。 printf("%10.2f%10.2f%10.2fn",ave_Chinese,ave_Math,ave_English>。 /* 显 示语文、数学、英语平均成绩 */puts("n"> 。printf(" Max_Chinese Max_Math Max_Englishn"> 。 printf("%10d%10d%10dn",Max0,Max1,Max2
20、> 。/* 显示语文、 英语成绩 */puts("n"> 。printf("ntThere are %d record.n",n>。puts("n"> 。printf(" 返回主菜单请按数字 0n">。do scanf("%d",&f> 。 if(f=0> menu(>。 break。else printf("输入有误,请重新输入 :"> 。while(f!=0> 。void search(>/*查找模
21、块 */int i,k,f 。struct student s。k=-1。 system("CLS">。/*清屏*/ printf("nnEnter name that you wang to search! num:">。 scanf("%s",&s.num>。 /* 输入要查找的学生的学号 */ printf("n NO :name Chinese Math English Max_coursen">。for (i=0。i<n。i+>/*查找信息 */ if(strc
22、mp(s.num,stui.num>=0> k=i 。/*找到要查找的学生记录 */printf_one(k>。 /* 调用显示一个记录函数 */ break。 if(k=-1> printf("nnNO exist!"> 。printf(" 返回主菜单请按数字 0n">。 do数学、average scanf("%d",&f> 。 if(f=0>menu(>。break。else printf("输入有误,请重新输入 :"> while(f!=0
23、> 。/*函数声明 */void order_ave(>。void order_Chinese(>。void order_Math(> 。void order_English(> 。void order(>/* 排序模块 */int i,j,f,m,w1 。struct student s。system("CLS">。doORDER system("CLS">。 puts("ttt 学 生 成 绩 排 序nn"> 。puts("t*n">。*n"
24、puts("ttt1.对每一位学生的平均成绩排序 n" puts("ttt2.对语文课成绩排序 n"。 puts("ttt3.对数学课成绩排序 n"。 puts("ttt4.对英语课成绩排序 n"。 puts("ttt5.返回主菜单 n"。puts("t*printf("Choice your number(1-5>: bb"> 。 scanf("%d",&m> 。if(m<0|m>5>w1=1。pri
25、ntf("your choice is not between 1 and 5,Please input again:">。getchar(>。 else w1=0。while(w1=1> 。 switch(m> /*选择功能 */case 1:order_ave(>。 break。case 2:order_Chinese(>。break。case 3:order_Math(>。break。case 4:order_English(>。 break。case 5:menu(>。printf("The order
26、ed data is:n">。browse(>。void order_ave(>/*对平均成绩从小到大进行冒泡排序法 */int i,j,f 。struct student s。system("CLS">。for(i=0 。i<n 。i+>for(j=i 。j<n 。j+>if(stui.ave>stuj.ave>s=stui。stui=stuj 。stuj=s。puts("n"> 。printf(" 每位学生的平均成绩从小到大的排序结果 n"> 。pr
27、intf(" NO : name average n">。for(i=0 。i<n 。i+>printf("%3s :%3s %11fn",stui.num,,stui.ave> 。 puts("n"> 。printf(" 返回上一级请按数字 0n">。doscanf("%d",&f> 。if(f=0>order(>。break。else printf("输入有误,请重新输入 :"> 。wh
28、ile(f!=0> 。void order_Chinese(>/*对语文成绩从小到大进行冒泡排序法 */int i,j,f 。struct student s。system("CLS">。for(i=0 。i<n 。i+>for(j=i 。j<n 。j+>if(stu_Chinesei.score0>stu_Chinesej.score0>s=stu_Chinesei。stu_Chinesei=stu_Chinesej。stu_Chinesej=s。puts("n"> 。printf("
29、; 语文成绩从小到大的排序结果 n"> 。printf(" NO : name Chinese n">。for(i=0 。i<n 。i+>printf("%3s :%5s %6dn",stu_Chinesei.num,stu_C,stu_Chin esei.score0>。puts("n"> 。printf(" 返回上一级请按数字 0n">。doscanf("%d",&f> 。if(f=0>order
30、(>。break。else printf("输入有误,请重新输入 :"> 。while(f!=0> 。void order_Math(>/* 对数学成绩从小到大进行冒泡排序法 */int i,j,f 。struct student s。system("CLS">。for(i=0 。i<n 。i+>for(j=i 。j<n 。j+>if(stu_Mathi.score1>stu_Mathj.score1>s=stu_Mathi。stu_Mathi=stu_Mathj 。 stu_Mathj=
31、s。puts("n"> 。printf(" 数学成绩从小到大的排序结果 n"> 。printf(" NO : name Math n"> 。for(i=0 。i<n 。i+>printf("%3s :%5s %6dn",stu_Mathi.num,stu_M,stu_Mathi.sc ore1>。puts("n"> 。printf(" 返回上一级请按数字 0n">。doscanf("%d",
32、&f> 。if(f=0>order(>。break。else printf("输入有误,请重新输入 :"> 。while(f!=0> 。void order_English(>/* 对英语成绩从小到大进行冒泡排序法 */int i,j,f 。struct student s。system("CLS">。for(i=0 。 i<n。 i+>for(j=i 。j<n 。j+>if(stu_Englishi.score2>stu_Englishj.score2>s=stu_Englishi。stu_Englishi=stu_Englishj 。stu_Englishj=s。puts("n"> 。printf(" 英语成绩从小到大的排序结果 n"> 。printf(" NO
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度不锈钢栏杆生产设备采购与技术升级合同
- 滑动门用非金属滑轨市场发展预测和趋势分析
- 纸制宠物拾便袋市场发展现状调查及供需格局分析预测报告
- 运载工具用电压调节器市场发展现状调查及供需格局分析预测报告
- 2024年度云计算服务合同数据处理规定
- 2024年度广告代理合同协议
- 2024年度中秋月饼定制采购合同
- 游泳池用充气玩具市场需求与消费特点分析
- 皮制行李标签市场需求与消费特点分析
- 2024年度劳动合同(含薪资待遇、工作时间及福利制度)
- 学校文印室外包服务 投标方案(技术方案)
- 北京市各区2023年高三(上)期末语文文学文本阅读汇编
- 2024年扬州市职业大学高职单招(英语/数学/语文)笔试历年参考题库含答案解析
- 前交叉韧带重建术后康复训练
- 物业费用测算表
- 学前教育实训项目
- 上海家政行业报告
- 游泳馆消防安全制度规范与管理
- 2024年中粮集团中粮贸易有限公司招聘笔试参考题库含答案解析
- 朱竞丰精准提分
- 影视拍摄服务类标书之服务承诺书
评论
0/150
提交评论