【计算机类职业资格】二级C语言-368及答案解析.doc

上传人:orderah291 文档编号:1325305 上传时间:2019-10-17 格式:DOC 页数:7 大小:36KB
下载 相关 举报
【计算机类职业资格】二级C语言-368及答案解析.doc_第1页
第1页 / 共7页
【计算机类职业资格】二级C语言-368及答案解析.doc_第2页
第2页 / 共7页
【计算机类职业资格】二级C语言-368及答案解析.doc_第3页
第3页 / 共7页
【计算机类职业资格】二级C语言-368及答案解析.doc_第4页
第4页 / 共7页
【计算机类职业资格】二级C语言-368及答案解析.doc_第5页
第5页 / 共7页
点击查看更多>>
资源描述

1、二级 C 语言-368 及答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun 的功能是重写形参 filename 所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #define N 5 typedef struct stude

2、nt long sno; char name10; float score3; STU; void fun(char *filename,STU n) FILE*fp; /*found*/ fp=fopen( 1,“rb+“); /*found*/ fseek( 2, -(long)sizeof (STU),SEEK_END); /*found*/ fwrite( fclose(fp); main() STU tN=10001,“MaChao“, 91,92,77,10002,“CaoKai“, 75,60,88, 10003,“LiSi“,85, 70,78,10004,“FangFang“

3、,90, 82,87, 10005,“ZhangSan“,95,80,88; STU n=10006,“ZhaoSi“,55,70,68,ssN; 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; jN; j+) printf“/nNo:

4、 %ld Name: %-8s Scores:“,ssj.sno,ssj.name); for(i=0; i3; i+) printf(“%6.2f“,ssj.scorei); 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; jN; j+) printf(“/nNo: % ld Name: %-8s Scores:“,ssj.sn

5、o,ssj.name); for(i=0; i3; i+) printf(“%6.2f“, ssj.scorei); printf(“/n“); (分数:30.00)二、程序修改题(总题数:1,分数:30.00)2.下列给定程序中函数 Creatlink 的功能是:创建带头结点的单向链表,并为各结点数据域赋 0 到 m-1 的值。 请改正函数 Creatlink 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #includestdlib.h typedef struct aa int

6、 data; struct aa * next; NODE; NODE * Creatlink(int n,int m) NODE *h=NULL, *p, *s; int i; /*found*/ p=(NODE)malloc(sizeof(NODE); h=p; p-next=NULL; for(i=1; i=n;i+) s=(NODE *)malloc(sizeof(NODE); s-data=rand()%m; s-next=p-next; p-next=s; p=p-next; /*found*/ return p; outlink(NODE * h) NODE * p; p=h-n

7、ext; printf(“/n/nTHE LIST:/n/nHEAD“); while(p) printf(“-%d“,p-data); p=p-next; printf(“/n“); main() (NODE*head; head=Creatlink(8,22); outlink(head); (分数:30.00)三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,该函数的功能是:统计一行字符串中单词的个数,作为函数值返回。字符串在主函数中输入,规定所有单词由小写字母组成,单词之间有若干个空格隔开,一行的开始没有空格。 注意:请勿改动 main 函数和其他函数中的任何内容,

8、仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #includestring.h #includestdio.h #define N 80 int fun(char *s) void main() FILE * wf; char lineN; int num=0; printf(“Enter a string:/n“); gets(line); num=fun(line); printf(“The number of wordis:%d/n/n“,num); /*found*/ wf=fopen(“out.dat“,“w“); fprintf(wf,“%d“,fun(“a bi

9、gcar“); fclose(wf); /*found*/ (分数:40.00)_二级 C 语言-368 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.程序通过定义学生结构体变量,存储了学生的学号、姓名和三门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun 的功能是重写形参 filename 所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下画线处填入正确的内容并把下画线删除,使程序得出正确的结果。 注意:不得增行或删行,也不得更改程序的结构! 试题程序: #include

10、stdio.h #define N 5 typedef struct student long sno; char name10; float score3; STU; void fun(char *filename,STU n) FILE*fp; /*found*/ fp=fopen( 1,“rb+“); /*found*/ fseek( 2, -(long)sizeof (STU),SEEK_END); /*found*/ fwrite( fclose(fp); main() STU tN=10001,“MaChao“, 91,92,77,10002,“CaoKai“, 75,60,88,

11、 10003,“LiSi“,85, 70,78,10004,“FangFang“,90, 82,87, 10005,“ZhangSan“,95,80,88; STU n=10006,“ZhaoSi“,55,70,68,ssN; 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 da

12、ta:/n/n“); for(j=0; jN; j+) printf“/nNo: %ld Name: %-8s Scores:“,ssj.sno,ssj.name); for(i=0; i3; i+) printf(“%6.2f“,ssj.scorei); 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; jN; j+) print

13、f(“/nNo: % ld Name: %-8s Scores:“,ssj.sno,ssj.name); for(i=0; i3; i+) printf(“%6.2f“, ssj.scorei); printf(“/n“); (分数:30.00)解析:(1)filename (2)fp (3)fp 解析 填空 1:本空是对文本文件的打开,filename 所指的文件中的最后数据要进行重写,因此首先是要打开,因而本空填写 filename。 填空 2:fseek 功能是重定位流上的文件指针。用法:int fseek(FILE*stream,long offset,int fromwhere);本

14、空应该填写 fp。 填空 3:因为题目中要对所有学生数据均以二进制方式输出到文件中,因此本空填写 fp。 知识点讲解: 函数名:fseek 功能:重定位流上的文件指针。 用法:int fseek(FILE*stream,long offset,int fromwhere)。 描述:函数设置文件指针 stream 的位置。如果执行成功,stream 将指向以 fromwhere 为基准(从文件的哪里开始偏移)、偏移 offset 个字节的位置。正数表示正向偏移,负数表示负向偏移。如果执行失败(比如 offset 超过文件自身大小),则不改变 stream 指向的位置。 返回值:成功,返回 0;否

15、则返回非 0 值。二、程序修改题(总题数:1,分数:30.00)2.下列给定程序中函数 Creatlink 的功能是:创建带头结点的单向链表,并为各结点数据域赋 0 到 m-1 的值。 请改正函数 Creatlink 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #includestdlib.h typedef struct aa int data; struct aa * next; NODE; NODE * Creatlink(int n,int m) NODE *h=NULL,

16、 *p, *s; int i; /*found*/ p=(NODE)malloc(sizeof(NODE); h=p; p-next=NULL; for(i=1; i=n;i+) s=(NODE *)malloc(sizeof(NODE); s-data=rand()%m; s-next=p-next; p-next=s; p=p-next; /*found*/ return p; outlink(NODE * h) NODE * p; p=h-next; printf(“/n/nTHE LIST:/n/nHEAD“); while(p) printf(“-%d“,p-data); p=p-n

17、ext; printf(“/n“); main() (NODE*head; head=Creatlink(8,22); outlink(head); (分数:30.00)解析:(1)p=(NODE*)malloc(sizeof(NODE); (2)return h; 解析 (1)由变量定义可知 p 为指向结点的指针。指向刚分配的结构指针,所以应改为 p=(NODE*)malloc(sizeof(NODE)。 (2)在动态分配内存的下一行语句是,使用临时结构指针变量 h 保存 p 指针的初始位置,最后返回不能使用 p,是因为 p 的位置已经发生了变化,所以应改为 return h。三、程序设计题

18、(总题数:1,分数:40.00)3.请编写函数 fun,该函数的功能是:统计一行字符串中单词的个数,作为函数值返回。字符串在主函数中输入,规定所有单词由小写字母组成,单词之间有若干个空格隔开,一行的开始没有空格。 注意:请勿改动 main 函数和其他函数中的任何内容,仅在函数 fun 的花括号中填入所编写的若干语句。 试题程序: #includestring.h #includestdio.h #define N 80 int fun(char *s) void main() FILE * wf; char lineN; int num=0; printf(“Enter a string:/n

19、“); gets(line); num=fun(line); printf(“The number of wordis:%d/n/n“,num); /*found*/ wf=fopen(“out.dat“,“w“); fprintf(wf,“%d“,fun(“a bigcar“); fclose(wf); /*found*/ (分数:40.00)_正确答案:()解析:int fun(char *s) int i,j=0; for(i=0;si!=“/0“;i+) if(si!=“ return j; /*返回单词个数*/ 解析 要判断单词的个数,首先想到的是程序怎样识别出一个单词,如果一个字母的下一个字符为空格或者结束标记,则表示一个单词结束,因此程序使用 for 循环语句遍历整个字符串,用 if 条件语句判断当前字符是否表示一个单词的结束,如果当前字符表示一个单词结束,则存放单词个数的变量加 1,最后返回单词的个数。

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1