C语言_学生成绩管理系统实验报告.doc
《C语言_学生成绩管理系统实验报告.doc》由会员分享,可在线阅读,更多相关《C语言_学生成绩管理系统实验报告.doc(13页珍藏版)》请在咨信网上搜索。
学生成绩管理系统实验报告 ㈠实验名称: 学生成绩管理系统 ㈡实验目的: 1)利用所学的三种程序基本结构以与数组、用户自定义函数进行一个简单管理系统的设计,进一步理解和掌握c语言的语法以与三种基本程序结构的综合应用。 2)通过程序中设计到的排序、查找、求和等操作加深对算法、程序设计思路、常用程序设计技巧的理解与掌握,逐步培养学生的程序开发能力。 ㈢实验要求: 设某班有n位同学,每位同学的数据包括一下容:学号(长整型)、(字符号)、数学成绩(整型)、程序设计成绩(整型)。设计程序完成以下5项功能:新建数据档案、添加数据、删除数据、对输入的数据进行排序和查询。 ㈣算法容: ①程序运行,利用printf函数显示主菜单,并提示输入相应的数字来进行相关操作。 显示主菜单如下: 1. 新建数据 2. 添加数据 3. 删除数据 4. 排序 5. 查询 6. 退出 ②若输入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-> n S7: 把要删除的数据覆盖 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->i S2:i+1->j S3:若a[i]<a[j],第i+1个学生数据与第j+1个学生数据进行交换 S4:j+1->j S5:若j<n,n为学生原有人数,返回S3 S6:i+1->i S7:若i<n-1,返回S2 s8:输出学生数据,算法结束 ⑥输入5,进入查询界面。 1)按学号和名字方法一样(以按学号为例) S1:输入要查询的学生的学号置于a[10]中 S2:0->i S3:若stu[i].num=a[10],输出该生数据并结束 S4:i+1->i S5:若i<n返回 S3否则输出“学号不存在”,算法结束 (2)按数学、程序设计、总分查询(以数学为例) S1:输入最低分数线m S2:0->i,0->j S3:若std[i].math=m,转到S6 S4:i+1->i S5:若i<n,返回S3 S6: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,返回S3 S8:0->i S9:输出学生数据 S10:i+1->i S11:i<j,返回S9,否则算法结束 ⑦输入6,结束,退出程序 ㈤程序清单 #include<string.h> #include<stdio.h> # define N 50 int n; struct student { char num[10]; char name[20]; int math,C,sum; }stu[N]; void put1() { void put2(); 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"); } void put2() { printf("********************************************************************************\n"); } void put3() { printf("学号 数学 程序设计 总分\n"); } void put4() { printf("操作结果如下:\n"); } void get(int i) { 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"); } void build() { printf("\n \t\t\t 新建数据\n"); int i; 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(); } void add() { printf("\n \t\t\t 添加数据\n\n"); int i; 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(); } void delet() { char str[10];int i,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(); } } void sort_1(int a[]) { int i,j,k,m,t;char str[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(); } void sort() { int i,q;int mat[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");goto loot;} else if (q==2){sort_1(c);printf("\t\t\t\n\n"); goto loot;} else if (q==3){sort_1(su);printf("\t\t\t\n\n");goto loot;} else if(q==4); } void seek_num() { char str[10];int i, 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输入的学号不存在"); } void seek_name() { char str[10];int i, 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输入的不存在"); } void seek_1(int a[N]) { int i,m,j=0,k;char e[50][50],b[50][50];int c[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(); } void seek() { int i,q;int mat[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");goto looa;} else if (q==2){seek_name();printf("\n\n");goto looa;} else if (q==3){seek_1(mat);printf("\n\n");goto looa;} else if(q==4){seek_1(c);printf("\n\n");goto looa;} else if(q==5){seek_1(su);printf("\n\n");goto looa;} else if (q==6); } void main() { int i,q;int mat[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");goto loop; } else if(q==2) { add();printf("\n\n");goto loop; } else if(q==3) { delet();printf("\n\n");goto loop; } else if(q==4) { sort();printf("\n\n");goto loop; } else if(q==5) { seek();printf("\n\n");goto loop; } else if(q==6) { printf("\t\t\t\n\n \t\t\t 使用!\n\n\n"); } } ㈥运行结果 原始界面 新建数据 添加数据 删除数据 成绩排序 成绩查询 退出界面 ㈦分析与思考 C语言的确是一门很难学的课程。原本以为做个程序是件简单的事情,但是想错了。要完完整整把程序按照要求编出来是意见很不容易的事情。 从开始看题目,一个个分部分的分析、设计、写算法等等,真的是头疼啊!虽然有些地方可以套用书上或者知道书上的例题,但是一点点把程序拼接起来,一步步修改还是好艰难的啊。只能向同学求助,帮忙一起弄弄程序!所以元旦放假这几天经常去图书馆上个机,搞搞程序,把程序中的上百个错误一点点减少到零个,出现我们想要的操作界面。这个上交的程序是我们比较满意的,但还是有些地方还不够好。比如说数据编排还不够美观,虽然作了较多的努力,但是结果都不是很理想,最后还是放弃了,只能这样勉强看看。 这个程序下来,我觉得做程序需要很大的耐心,一个大点的程序有个几百甚至上千个步骤,没有耐心是做不成功的。当然细心也很需要,有很多错误都是自己的粗心造成的,有时甚至自己以遍遍检查都看不出来,还以为是什么大错误呢。但是即使是有一点点小错误,编的再怎么完美的程序也无常运行。所以编程序也是在锻炼一个人啊。 现在觉得我们学的东西还是比较少的,一个稍微大点的程序就把我们弄的这么痛苦,还是要多学点,多实践,才能真正掌握好。在以后的日子,要想把编程学好还是要下很大一番苦功夫的啊,所以要努力了啊! 13 / 13- 配套讲稿:
如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。
关于本文