




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
学生成绩管理系统试验汇报㈠试验名称:学生成绩管理系统㈡试验目标:1)利用所学三种程序基础结构和数组、用户自定义函数进行一个简单管理系统设计,深入了解和掌握c语言语法和三种基础程序结构综合应用。2)经过程序中设计到排序、查找、求和等操作加深对算法、程序设计思绪、常见程序设计技巧了解和掌握,逐步培养学生程序开发能力。㈢试验要求:设某班有n位同学,每位同学数据包含一下内容:学号(长整型)、姓名(字符号)、数学成绩(整型)、程序设计成绩(整型)。设计程序完成以下5项功效:新建数据档案、添加数据、删除数据、对输入数据进行排序和查询。㈣算法内容:①程序运行,利用printf函数显示主菜单,并提醒输入对应数字来进行相关操作。显示主菜单以下:新建数据添加数据删除数据排序查询退出②若输入1,则进入新建数据界面。依据提醒依次输入学生人数、学生学号、姓名、数学成绩和程序设计程序。S1:输入学生人数n,
S2:0->i,(把0放在变量i中)
S3:输入第i+1个学生数据(学号,姓名,学数学成绩,程序设计成绩)
S4:i+1->i
S5:若i<n,返回S2,不然继续
S6:0=<i
S7:输出第i+1个学生数据
S8:i+1=i
若i<N,返回s6不然结束算法③输入2,进入添加数据界面。S1:原有学生人数n加1,即n+1=>n
S2:输入学生数据
S3:0->i
S4:输出第i+1个学生数据
S5:若i<n返回S4,不然结束算法④输入3进入删除数据界面。S1:输入要删除学生学号m
S2:0->i,0->j
S3:若学生学号stu[i].num,转到S6,不然继续
S4:i+1->i
S5:若i<n,返回S3,不然输出“输出学号不存在”算法接速
S6:n-1->nS7:把要删除数据覆盖
stu[i].num=>stu[j].num;stu[i].name=>stu[j].name;
stu[i].math=stu[j].math;stu[i].C=stu[j].C;j++;
S8:若i<n,返回S7,不然继续S9:0->i
S10:输出第i+1个学生数据
S11:若i<n返回S10,不然结束算法⑤输入4,进入排序界面。按三种方法排序本质一样一下用数组a[50]代表S1:0->iS2:i+1->jS3:若a[i]<a[j],第i+1个学生数据和第j+1个学生数据进行交换S4:j+1->jS5:若j<n,n为学生原有些人数,返回S3S6:i+1->iS7:若i<n-1,返回S2s8:输出学生数据,算法结束⑥输入5,进入查询界面。1)按学号和名字方法一样(以按学号为例)S1:输入要查询学生学号置于a[10]中S2:0->iS3:若stu[i].num=a[10],输出该生数据并结束S4:i+1->iS5:若i<n返回S3不然输出“学号不存在”,算法结束(2)按数学、程序设计、总分查询(以数学为例)S1:输入最低分数线mS2:0->i,0->jS3:若std[i].math=m,转到S6S4:i+1->iS5:若i<n,返回S3S6:strcpy(e[j],stu[i].num);strcpy(b[j],stu[i].name);c[j]=stu[i].math;d[j]=stu[i].C;
(其中数组e,b,c,d是二维数组)S7:j+1->j,返回S3S8:0->iS9:输出学生数据S10:i+1->iS11:i<j,返回S9,不然算法结束⑦输入6,结束,退出程序㈤程序清单#include<string.h>#include<stdio.h>#defineN50intn;structstudent{charnum[10];charname[20];intmath,C,sum;}stu[N];voidput1(){voidput2();put2();printf("\t\t\t\t学生成绩管理系统\n\t\t\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");put2();printf("\n");}voidput2(){printf("********************************************************************************\n");}voidput3(){printf("学号姓名数学程序设计总分\n");}voidput4(){printf("操作结果以下:\n");}voidget(inti){printf("\t\t\t请输入学号:");scanf("%s",stu[i].num);printf("\t\t\t请输入姓名:");scanf("%s",stu[i].name);printf("\t\t\t请输入数学成绩:");scanf("%d",&stu[i].math);printf("\t\t\t请输入程序设计成绩:");scanf("%d",&stu[i].C);printf("\n");}voidbuild(){printf("\n\t\t\t新建数据\n");inti;printf("\n\t\t\t请输入学生人数:");scanf("%d",&n);printf("\n");for(i=0;i<n;i++)get(i);printf("\n");put4();put2();put3();for(i=0;i<n;i++)printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();}voidadd(){printf("\n\t\t\t添加数据\n\n");inti;n=n+1;get(n-1);put4();put2();put3();for(i=0;i<n;i++)printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();}voiddelet(){charstr[10];inti,j=0,k=0;printf("\n\t\t\t删除数据\n\n");printf("\t\t\t请输入要删除学生学号:");scanf("%s",str);for(i=0;i<n;i++){if(strcmp(str,stu[i].num)==0)k++;else{stu[j].num=stu[i].num;stu[j].name=stu[i].name;stu[j].math=stu[i].math;stu[j].C=stu[i].C;j++;}}if(k==0)printf("\t\t\t输入学号不存在\n");else{put4();put2();put3();n=n-1;for(i=0;i<n;i++)printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();}}voidsort_1(inta[]){inti,j,k,m,t;charstr[20];for(i=0;i<n-1;i++)for(j=i+1;j<n;j++)if(a[i]<a[j]){strcpy(str,stu[i].num);strcpy(stu[i].num,stu[j].num);strcpy(stu[j].num,str);strcpy(str,stu[i].name);strcpy(stu[i].name,stu[j].name);strcpy(stu[j].name,str);t=stu[i].math;stu[i].math=stu[j].math;stu[j].math=t;t=stu[i].C;stu[i].C=stu[j].C;stu[j].C=t;}put4();put2();put3();for(i=0;i<n;i++)printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();}voidsort(){inti,q;intmat[N],c[N],su[N];loot:for(i=0;i<n;i++){mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}printf("\n\t\t\t成绩排序\n\n");put2();printf("\t\t\t1.数学成绩排序\n\t\t\t2.程序设计排序\n\t\t\t3.总分排序\n\t\t\t4.返回主菜单\n");put2();printf("\t\t\t请选择排序方法序号1-4:");scanf("%d",&q);if(q==1){sort_1(mat);printf("\t\t\t\n\n");gotoloot;}elseif(q==2){sort_1(c);printf("\t\t\t\n\n");gotoloot;}elseif(q==3){sort_1(su);printf("\t\t\t\n\n");gotoloot;}elseif(q==4);}voidseek_num(){charstr[10];inti,k=0;printf("\t\t\t请输入学号:");scanf("%s",str);for(i=0;i<n;i++)if(strcmp(str,stu[i].num)==0){put4();put2();put3();printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();break;}if(i==n)printf("\t\t\t输入学号不存在");}voidseek_name(){charstr[10];inti,k=0;printf("\t\t\t请输入姓名:");scanf("%s",str);for(i=0;i<n;i++)if(strcmp(str,stu[i].name)==0){put4();put2();put3();printf("%-6s%-6s%4d%8d%8d\n",stu[i].num,stu[i].name,stu[i].math,stu[i].C,stu[i].math+stu[i].C);put2();break;}if(i==n)printf("\t\t\t输入姓名不存在");}voidseek_1(inta[N]){inti,m,j=0,k;chare[50][50],b[50][50];intc[50],d[50];printf("\t\t\t请输入分数下线:");scanf("%d",&m);for(i=0;i<n;i++)if(a[i]>=m){strcpy(e[j],stu[i].num);strcpy(b[j],stu[i].name);c[j]=stu[i].math;d[j]=stu[i].C;j++;}put4();put2();put3();for(i=0;i<j;i++)printf("%-6s%-6s%4d%8d%8d\n",e[i],b[i],c[i],d[i],c[i]+d[i]);put2();}voidseek(){inti,q;intmat[N],c[N],su[N];for(i=0;i<n;i++){mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}looa:printf("\n\t\t\t成绩查询\n\n");put2();printf("\t\t\t1.学号查询\n2.姓名查询\n3.数学成绩查询\n4.程序设计查询\n5.总分排序查询\n6.返回主菜单\n");put2();printf("\t\t\t请选择查询方法1-6:");scanf("%d",&q);if(q==1){seek_num();printf("\n\n");gotolooa;}elseif(q==2){seek_name();printf("\n\n");gotolooa;}elseif(q==3){seek_1(mat);printf("\n\n");gotolooa;}elseif(q==4){seek_1(c);printf("\n\n");gotolooa;}elseif(q==5){seek_1(su);printf("\n\n");gotolooa;}elseif(q==6);}voidmain(){inti,q;intmat[N],c[N],su[N];for(i=0;i<n;i++){mat[i]=stu[i].math;c[i]=stu[i].C;su[i]=stu[i].math+stu[i].C;}loop:put1();printf("\t\t\t假如还没新建数据,请先新建数据\n\n");printf("\t\t\t请选择要操作步骤序号1-6:");scanf("%d",&q);if(q==1){build();printf("\n\n");gotoloop;}elseif(q==2){add();printf("\n\n");gotoloop;}elseif(q==3){delet();printf("\
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 北京2025年北京开放大学招聘14人笔试历年参考题库附带答案详解
- 加油站承包合同二零二五年
- 2025新疆中新建能源矿业有限责任公司部分岗位市场化招聘(2人)笔试参考题库附带答案详解
- 沧州门面房租赁合同
- 建筑工程消防技术咨询协议书二零二五年
- 场地承包经营合同范例二零二五年
- 制药企业安全生产教育培训
- 2025企业借款抵押合同协议样本
- 2025b广东省商品房买卖合同
- 《2025年严格履行合同签订流程的通知书》
- 商户外摆合作协议
- 2024《整治形式主义为基层减负若干规定》全文课件
- 医保药品管理制度
- 四年级下册劳动教育全册教学课件
- 魁北克大桥事件案例分析工程伦理
- 医院检验申请单
- GB/T 29178-2012消防应急救援装备配备指南
- 二年级上册美术教案-第3课 点线面|冀教版
- 国家开放大学《机电一体化系统实训作业》参考答案
- 部编人教版五年级下册道德与法治《虎门销烟》【获奖作品】课件
- 高层外墙GRC拆除方案
评论
0/150
提交评论