- 1、本文档共16页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
计算机二级考试C语言练习题
/computer/djks/dj2/C/shangji/201107/2084141.html一、填空题:
程序通过定义学生结构体变量,存储了学生的学号、姓名和3门课的成绩。所有学生数据均以二进制方式输出到文件中。函数fun的功能是重写形参filename所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其它学生的数据不变。
请在程序的下划线处填入正确的内容并把下划线删除, 使程序得出正确的结果。
注意:源程序存放在考生文件夹下BLANK1.C中。
不得增行或删行,也不得更改程序的结构!
给定源程序:
#include
#define N 5
typedef struct student {
long sno;
char name[10];
float score[3];
} STU;
void fun(char *filename, STU n)
{FILE *fp;
/**********found**********/
fp = fopen(__1__, rb+);
/**********found**********/
fseek(__2__, -(long)sizeof(STU), SEEK_END);
/**********found**********/
fwrite(n, sizeof(STU), 1, __3__);
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}};
STU n={10006,ZhaoSi, 55, 70, 68}, ss[N];
int i,j; FILE *fp;
fp = fopen(student.dat, wb);
fwrite(t, sizeof(STU), N, fp);
fclose(fp);
fp = fopen(student.dat, rb);
fread(ss, sizeof(STU), N, fp);
fclose(fp);
printf(\nThe original data :\n\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);
}
fun(student.dat, n);
printf(\nThe data after modifing :\n\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);
}
}
解题答案:
/**********第一空**********/
fp = fopen(filename, rb+);
/**********第二空**********/
fseek(fp, -(long)sizeof(STU), SEEK_END);
/**********第三空**********/
fwrite(n, sizeof(STU), 1, fp);
******************************************
二、改错题:给定程序MODI1.C中的函数Creatlink的功能是创建带头结点的单向链表, 并为各结点数据域赋0到m-1的值。
请改正函数Creatlink中指定部位的错误, 使它能得出正确的结果。
注意: 不要改动main函数, 不得增行或删行, 也不得更改程序的结构!
给定源程序:
#include
#include
typedef struct aa
{int data;
struct aa *next;
} NOD
文档评论(0)