(实训项目五学生成绩文件管理实验报告.docVIP

(实训项目五学生成绩文件管理实验报告.doc

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
学生实验报告 实验课名称: C语言程序设计 实验项目名称:学生成绩文件管理 专业名称: 通信工程 班级:学号: 2404100238 学生姓名: 郭 媛 教师姓名: 卢 江 2011 年 6 月 18 日 实验日期: 2011 年 6 月 18日 实验室名称: 计算机实验中心 一.实验名称: 学生成绩文件管理 二.实验目的与要求: 掌握文件指针的概念和运用 掌握文件的相关操作:打开、读、写、关闭 掌握文件的定位操作 三.实验内容: 一、实训设备与工具 个人计算机(奔腾486档以上), Win操作系统,Turbo C 2.0或 VC++6.0编译开发环境 二、实训内容、步骤、方法与要求 定义一个结构体数组,存放10个学生的学号,姓名,三门课的成绩 从键盘输入10个学生的以上内容,存入文件stu.dat,关闭文件 打开stu.dat文件,将数据读出,查看是否正确写入,关闭文件。 打开文件stu.dat文件,读出数据,将10个学生按照平均分数从高到低进行排序, 分别将结果输出到屏幕上和另一文件stusort.dat中。 从stusort.dat 文件中读取第2,4,6,8,10个学生的数据。 在项目报告中画出程序流程图,说明程序设计的算法,附主要程序段。 在项目报告中说明知识点。将结果截图并在图空白处标识自己的班级学号姓名。 在项目报告中说明程序设计过程中的难点、解决办法及编程小结或体会。 四.算法描述: 定义学生信息结构体,将数据写入文件stu.dat,计算每人平均分,从文件中读取信息,排序后输出到屏幕和文件stusort.dat中,并在stusort.dat中读取所需学生信息 流程图: 五.源程序: #include stdio.h #define N 10 struct student {int num; char name[10]; int math; int chinese; int english; }; struct student stu[N],stu1[N],t; void main() { FILE *fp; int i,k,w; float ave[N],h; for(i=0;iN;i++) scanf (%d%s%d%d%d,stu[i].num,stu[i].name,stu[i].math, stu[i].chinese,stu[i].english); if((fp=fopen(stu.dat,w+))==NULL) printf(Error!\n); else {for(i=0;iN;i++) fwrite(stu[i],sizeof(struct student),1,fp); fclose(fp); } if((fp=fopen(stu.dat,r+))==NULL) printf(Error!\n); else {for(i=0;iN;i++) fread(stu[i],sizeof(struct student),1,fp); fclose(fp); } for(i=0;iN;i++) {printf(\n); printf(%d %s %d %d %d\n,stu[i].num,stu[i].name,stu[i].math, stu[i].chinese,stu[i].english); ave[i]=(float)(stu[i].math+stu[i].chinese+stu[i].english)/3;} for(i=0;iN-1;i++) {w=i; for(k=i+1;kN;k++) if(ave[w]ave[k]) w=k; t=stu[w];stu[w]=stu[i];stu[i]=t; h=ave[w];ave[w]=ave[i];ave[i]=h; } for(i=0;iN;i++) printf(%d\t%s\t%d\t%d\t%d\t%f\n,stu[i].num,stu[i].name, stu[i].math,stu[i].chinese,stu[i].english,ave[i]); if((fp=fopen(stusort.dat,w+))==NULL) printf(Error!\n); else {for(i=0;iN;i++) fwrite(stu[i],sizeof(struct student),1,fp); fclose(fp);} if((fp=fopen(stusort.dat,r+))==NULL) printf(Error!\n); else {for(i=0;iN;i++)

文档评论(0)

JPEYPGTeaa + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档