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

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

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

2、tudent 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; inti,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:%ld Na

4、me:%-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. sno,ssj.name);

5、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 data; struct a

6、a*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-next; printf(“/n/nTHE LIST:/

7、n/n HEAD“); 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 函数和其他函数中的任何内容,仅在函数 fun 的花括号中

8、填入所编写的若干语句。 试题程序: #includestring.h #includestdio.h #define N 80 int fun(char*s) void main() char lineN; int num=0; printf(“Enter a string:/n“); gets(line); num=fun(line); printf(“The number of word is:%d/n/n“,num); (分数:40.00)_二级 C 语言-348 答案解析(总分:100.00,做题时间:90 分钟)一、程序填空题(总题数:1,分数:30.00)1.程序通过定义学生结构体

9、变量,存储了学生的学号、姓名和三门课的成绩。所有学生数据均以二进制方式输出到文件中。函数 fun 的功能是重写形参 filename 所指文件中最后一个学生的数据,即用新的学生数据覆盖该学生原来的数据,其他学生的数据不变。 请在程序的下划线处填入正确的内容,使程序得出正确的结果。 注意:部分源程序给出如下。 不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #define N 5 typedef struct student long sno; char name10; float score3; STU; void fun(char*filename,STU

10、 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“,90,82,87,10005,“ZhangSan“,95,80,88; STU n=10006,“ZhaoSi“,55,70,68,ssN; inti

11、,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:%ld Name:%-8s Scores:“,ssj. sno,ssj.name); for(i=0;i3;i+) printf(“%6.2f“ssj.score

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

13、ilename (2)fp (3)fp 解析 填空 1:本空是对文本文件的打开,filename 所指的文件中的最后数据要进行重写,因此首先是要打开,因而本空填写 filename。 填空 2:fseek 功能是重定位流上的文件指针。用法: int fseek(FILE *stream, long offset, int fromwhere);本空应该填写 fp。 填空 3:因为题目中要对所有学生数据均以二进制方式输出到文件中,因此本空填写 fp。 知识点讲解: 函数名: fseek 功 能: 重定位流上的文件指针。 用 法: int fseek(FILE *stream, long offs

14、et, int fromwhere)。 描 述: 函数设置文件指针 stream 的位置。如果执行成功,stream 将指向以 fromwhere 为基准,偏移offset 个字节的位置。如果执行失败(比如 offset 超过文件自身大小),则不改变 stream 指向的位置。 返回值: 成功,返回 0;否则返回非 0 值。二、程序改错题(总题数:1,分数:30.00)2.下列给定程序中函数 Creatlink 的功能是:创建带头结点的单向链表,并为各结点数据域赋 0 到 m-1 的值。 请改正函数 Creatlink 中指定部位的错误,使它能得出正确的结果。 注意:不要改动 main 函数,

15、不得增行或删行,也不得更改程序的结构! 试题程序: #includestdio.h #includestdlib.h typedef struct aa int 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;

16、p-next=s;p=p-next; /*found*/ return p; outlink(NODE*h) NODE*p; p=h-next; printf(“/n/nTHE LIST:/n/n HEAD“); while(p) (printf(“-%d“,p-data); p=p-next; printf(“/n“); main() NODE*head; head=Creatlink(8,22); outlink(head); (分数:30.00)_正确答案:()解析:(1)p=(NODE *)malloc(sizeof(NODE); (2)return h; 解析 (1)由变量定义可知

17、p 为指向结点的指针。指向刚分配的结构指针,所以应改为p(NODE *)malloc(sizeof(NODE)。 (2)在动态分配内存的下一行语句是,使用临时结构指针变量 h 保存 p 指针的初始位置,最后返回不能使用 p,是因为 p 的位置已经发生了变化,所以应改为 return h。三、程序设计题(总题数:1,分数:40.00)3.请编写函数 fun,该函数的功能是:统计一行字符串中单词的个数,作为函数值返回。字符串在主函数中输入,规定所有单词由小写字母组成,单词之间有若干个空格隔开,一行的开始没有空格。 注意:部分源程序给出如下。 请勿改动 main 函数和其他函数中的任何内容,仅在函数

18、 fun 的花括号中填入所编写的若干语句。 试题程序: #includestring.h #includestdio.h #define N 80 int fun(char*s) void main() char lineN; int num=0; printf(“Enter a string:/n“); gets(line); num=fun(line); printf(“The number of word is:%d/n/n“,num); (分数: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