2011年C语言上机操作题及答案六..doc

  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
2011年C语言上机操作题及答案六.

  一、填空题:程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到student.dat文件中。函数fun的功能是从指定文件中找出指定学号的学生数据,读入此学生数据,对该生的分数进行修改,使每门课的分数加3分,修改后重写文件中该学生的数据,即用该学生的新数据覆盖原数据,其它学生数据不变;若找不到,则什么都不做。   请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。   注意:源程序存放在考生文件夹下BLANK1.C中。   不得增行或删行,也不得更改程序的结构!   给定源程序:   #include   #define N 5   typedef struct student {   long sno;   char name[10];   float score[3];   } STU;   void fun(char *filename, long sno)   {FILE *fp;   STU n; int i;   fp = fopen(filename,rb+);   /**********found**********/   while (!feof(__1__))   {fread(n, sizeof(STU), 1, fp);   /**********found**********/   if (n.sno__2__sno) break;   }   if (!feof(fp))   {for (i=0; i3; i++) n.score[i] += 3;   /**********found**********/   fseek(__3__, -(long)sizeof(STU), SEEK_CUR);   fwrite(n, sizeof(STU), 1, fp);   }   fclose(fp);   }   main()   {STU t[N]={ {10001,MaChao, 91, 92, 77}, {10002,CaoKai, 75, 60, 88},{10003,LiSi, 85, 70, 78}, {10004,FangFang, 90, 82, 87},{10005,ZhangSan, 95, 80, 88}}, ss[N];   int i,j; FILE *fp;   fp = fopen(student.dat, wb);   fwrite(t, sizeof(STU), N, fp);   fclose(fp);   printf(\nThe original data :\n);   fp = fopen(student.dat, rb);   fread(ss, sizeof(STU), N, fp);   fclose(fp);   for (j=0; j   {printf(\nNo: %ld Name: %-8s Scores: ,ss[j].sno, ss[j].name);   for (i=0; i3; i++) printf(%6.2f , ss[j].score[i]);   printf(\n);   }   fun(student.dat, 10003);   fp = fopen(student.dat, rb);   fread(ss, sizeof(STU), N, fp);   fclose(fp);   printf(\nThe data after modifing :\n);   for (j=0; j   {printf(\nNo: %ld Name: %-8s Scores: ,ss[j].sno, ss[j].name);   for (i=0; i3; i++) printf(%6.2f , ss[j].score[i]);   printf(\n);   }   }   解题答案:   /**********第一空**********/   while (!feof(fp))   /**********第二空**********/   if (n.sno==sno) break;   /**********第三空*********/   fseek(fp, -(long)sizeof(STU), SEEK_CUR);   二、改错题:给定程序MODI1.C中函数fun的功能是:利用插入排序法对字符串中的字符按从小到大的顺序进行排序。插入法的基本算法是:先对字符串中的头两个元素进行排序。然后把第三个字符插入到前两个字符中,插入后前三个字符依然有序;再把第四个字符插入到前三个字符中,……。待排序的字符串已在主函数中赋予。   请改正程序中的错误,使它能得出

文档评论(0)

haihang2017 + 关注
实名认证
内容提供者

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

1亿VIP精品文档

相关文档