【计算机类职业资格】二级C语言笔试-293及答案解析.doc
《【计算机类职业资格】二级C语言笔试-293及答案解析.doc》由会员分享,可在线阅读,更多相关《【计算机类职业资格】二级C语言笔试-293及答案解析.doc(32页珍藏版)》请在麦多课文档分享上搜索。
1、二级 C 语言笔试-293 及答案解析(总分:90.00,做题时间:90 分钟)一、选择题(总题数:50,分数:50.00)1.下列函数的运行结果是main ( )int i=2,p;int j,k;j=i;k=+i;p=f(j,k);printf(“%d“,p); int f(int a,int b)int c;if(ab)c=1;else if(a=b)c=0;else c=-1;return(c);(分数:1.00)A.-1B.1C.2D.编译出错,无法运行2.阅读下面程序,则执行后的结果是#include“stdio.h“main()char str=“tomeetme“,*p;for
2、(p=str;pstr+7;p+=2)putchar(*p);printf(“/n“); (分数:1.00)A.tomeetmeB.tmemC.oeteD.tome3.下列关于字符串的说法中错误的是(分数:1.00)A.在 C 语言中,字符串是借助于字符型一维数组来存放的,并规定以字符/0作为字符串结束标志B./0作为标志占用存储空间,计入串的实际长度C.在表示字符串常量的时候不需要人为在其末尾加入/0D.在 C 语言中,字符串常量隐含处理成以/0结尾4.下面四个选项中,均是不正确的 8 进制数或 16 进制数的选项是(分数:1.00)A.016 0x8f 018B.0abc 017 0xaC
3、.010 -0x11 0x16D.0a12 7ff -1235.有以下程序#includestdlib.hstruct NODEint num;struct NODE*next;main()struct NODE*p,*q,*r;p=(struct NODE*)malloc(sizeof(struct NODE);q=(struct NODE*)malloc(sizeof(struct NODE);r=(struct NODE*)malloc(sizeof(struct NODE);p-num=10;q-num=20;r-num=30;p-next=q;q-next=r;printf(“%d/
4、n“,p-num+q-next-num);程序运行后的输出结果是(分数:1.00)A.10B.20C.30D.406.以下程序有错,错误原因是main()int*p,i;char*q,ch;p= p= scanf(“%c, p=(char*)malloc(1) scanf(“%c“,p);C.char *p *p=getchar( );D.char *p,ch;p=*p=getchar( );13.以下叙述中正确的是(分数:1.00)A.程序应尽可能短B.为了编程的方便,应当根据编程人员的意图使程序的流程随意转移C.虽然注释会占用较大篇幅,但程序中还是应有尽可能详细的注释D.在 TURBO C
5、 环境下,运行的程序就是源程序14.下列数据模型中,具有坚实理论基础的是(分数:1.00)A.层次模型B.网状模型C.关系模型D.以上 3 个都是15.线性表 L=(a1,a2,a3,ai、an),下列说法正确的是(分数:1.00)A.每个元素都有一个直接前件和直接后件B.线性表中至少要有一个元素C.表中诸元素的排列顺序必须是由小到大或由大到小D.除第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件和直接后件16.软件开发离不开系统环境资源的支持,其中必要的测试数据属于(分数:1.00)A.硬件资源B.通信资源C.支持软件D.辅助资源17.有如下程序:long fib(int
6、n)if(n2)return(fib(n-1)+fib(n-2);else return(2);main()printf(“%d/n“,fib(3);该程序的输出结果是(分数:1.00)A.2B.4C.6D.818.下面函数的功能是char*fun(char*strl,char*str2)while(*strl)(分数:1.00)A.求字符串的长度B.比较两个字符串的大小C.将字符串 str1 复制到字符串 str2 中D.将字符串 str1 接续到字符串 str2 中19.阅读以下程序及对程序功能的描述,其中正确的描述是#includestdio.hmain()FILE*in,*out;ch
7、ar ch,infile10,outfile10;printf(“Enter the infile name:/n“);scanf(“%s“,infile);printf(“Enter the outfile name:/n“);scanf(“%s“,outfile);if(in=fopen(infile,“r“)=NULL)printf(“cannot open infile/n“);exit(0);if(out=fopen(outfile,“w“)=NULL)printf(“cannot open outfile/n“);exit(0);while(!feof(in)fputc(fgetc
8、(in),out);fclose(in);fclose(out);(分数:1.00)A.程序完成将磁盘文件的信息在屏幕上显示的功能B.程序完成将两个磁盘文件合二为一的功能C.程序完成将一个磁盘文件复制到另一个磁盘文件中D.程序完成将两个磁盘文件合并并在屏幕上输出20.对以下说明语句的正确理解是int a10=6,7,8,9,10;(分数:1.00)A.将 5 个初值依次赋给 a1至 a5B.将 5 个初值依次赋给 a0至 a4C.将 5 个初值依次赋给 a6至 a10D.因为数组长度与初值的个数不相同,所以此语句不正确21.设 p1 和 p2 是指向一个 int 型一维数组的指针变量,k 为
9、int 型变量,则不能正确执行的语句是(分数:1.00)A.k=*p1+*p2B.p2=k;C.p1=p2;D.k=*p1*(*p2);22.在位运算中,操作数右移一位,其结果相当于(分数:1.00)A.操作数乘以 2B.操作数除以 2C.操作数乘以 4D.操作数除以 423.设变量 a 是 int 型,f 是 float 型,i 是 double 型,则表达式 10+a+i*f 值的数据类型为(分数:1.00)A.intB.floatC.doubleD.不确定24. (分数:1.00)A.B.C.D.25.设有如下定义:struct skint n;float x; data,*p;若要使
10、p 指向 data 中的 n 域,正确的赋值语句是(分数:1.00)A.p=iM;i+)for(j=0;jN;j+)aij=i+j-(i-j);fun((分数:1.00)A.;A) 3B) 4C) 5D40.设有程序段int k=10;while(k=0)k=k-1;则下面描述中正确的是(分数:1.00)A.while 循环执行 10 次B.循环是无限循环C.循环体语句一次也不执行D.循环体语句执行一次41.软件工程的出现是由于(分数:1.00)A.程序设计方法学的影响B.软件产业化的需要C.软件危机的出现D.计算机的发展42.若运行以下程序时,从键盘输入 ADescriptorCR(CR表示
11、回车),则下面程序的运行结果是#includestdio.hmain()char c;int v0=1,v1=0,v2=0;do switch(c=getchar()casea:caseA:case e:case E:case i:case I:case o:case O:case u:case U:v1+=1default:v0+=1;v2+=1;while(c!=/n);printf(“v0=%d,v1=%d,v2=%d/n“,v0,v1,v2);(分数:1.00)A.v0=7,v1=4,v2=7B.v0=8,v1=4,v2=8C.v0=11,v1=4,v2=11D.v0=13,v1=4,
12、v2=1243.设 x,y 和 z 都是 int 型变量,且 x=3,y=4,z=5,则下面表达式中,值为 0 的表达式是(分数:1.00)A.xwhile(strcmp(s,“End“)printf(“Input a string:“);gets(s);while(*p)putchar(*p+);(分数:1.00)A.此程序循环接收字符串并输出,直到接收字符串“End“为止B.此程序循环接收字符串,接收到字符串“End“则输出,否则程序终止C.此程序循环接收字符串并输出,直到接收字符串“End“为止,但因为代码有错误,程序不能正常工作D.此程序循环接收字符串并将其连接在一起,直到接收字符串“
13、End“为止,输出连接在一起的字符串47.在单链表中,增加头结点的目的是(分数:1.00)A.方便运算的实现B.使单链表至少有一个结点C.标识表结点中首结点的位置D.说明单链表是线性表的链式存储实现48.假设线性表的长度为 n,则在最坏情况下,冒泡排序需要的比较次数为(分数:1.00)A.log2nB.n2C.O(n1.5)D.n(n-1)/249.以下程序的输出结果是#includestdio.hmain()union un int i;long k;char c;struct byteint a;long b;union un c;r;printf(“%d/n“,sizeof(r);(分数
14、:1.00)A.10B.13C.7D.850.函数的值通过 return 语句返回,下面关于 return 语句的形式描述错误的是(分数:1.00)A.return 表达式;B.return(表达式);C.一个 return 语句可以返回多个函数值D.一个 return 语句只能返回一个函数值二、填空题(总题数:16,分数:40.00)51.在算法正确的前提下,评价一个算法的两个标准是 【1】 。(分数:2.00)填空项 1:_52.将代数式 (分数:2.00)填空项 1:_53.软件危机出现于 60 年代末,为了解决软件危机,人们提出了 【3】 的原理来设计软件,这就是软件工程诞生的基础。(
15、分数:2.00)填空项 1:_54. 【4】 是数据库设计的核心。(分数:2.00)填空项 1:_55.在关系模型中,把数据看成一个二维表,每一个二维表称为一个 【5】 。(分数:2.00)填空项 1:_56.下列程序的输出结果是 【6】 。#define PR(a)printf(“%d/t“,(int)(a)#define PRINT(a)PR(a);printf(“ok!“)main()int i,a=1;for(i=0;i3;i+)PRINT(a+i);printf(“/n“);(分数:2.00)填空项 1:_57.关系表达式 xyz,用 C 语言的表达式为 【7】 。(分数:2.00)
16、填空项 1:_58.下面程序的功能是将一个字符串 str 的内容颠倒过来,请填空。#includestring.hmain()inti,j, 【8】 ;char str=“1234567“;for(i=0,j=strlen(str) 【9】 ;ij;i+,j-)k=stri;stri=strj;strj=k;printf(“%s/n“,str);(分数:4.00)填空项 1:_59.以下函数用来求出数组的最大元素在数组中的下标并存放在 k 所指的存储单元中。请填空。#includeconio.h#includestdio.hint fun(int*s,int t,int*k)int i;*k=
17、0;【10】 if(s*ksi)*k=i;return 【11】 ;main()int a10=876,675,896,101,301,401,980,431,451,777,k;clrscr();fun(a,10,for(i=0;i3;i+)ai+=ai;for(i=0;i3;i+)printf(“%d,“,ai);printf(“/n“);(分数:2.00)填空项 1:_64.下面函数要求计算两个整数 x,y 之和,并通过形参返回该值,请填空。add(int x,int y, 【16】 z)【17】 =x+y;(分数:4.00)填空项 1:_65.若用 0 至 9 之间不同的三个数构成一个
18、三位数,下面程序将统计出共有多少种方法。请填空。#includestdio.hmain()int i,j,k,count=0;for(i=0;i=9;i+)for(j=0;i=9;j+)if( 【18】 )continue;else for(k=0;k=9;k+)if( 【19】 )count+;printf(“%d“,count);(分数:4.00)填空项 1:_66.以下定义的结构体类型拟包含两个成员,其中成员变量 info 用来存入整形数据;成员变量 link 是指向自身结构体的指针,请将定义补充完整。struct nodeint info;【20】 link;(分数:2.00)填空项
19、1:_二级 C 语言笔试-293 答案解析(总分:90.00,做题时间:90 分钟)一、选择题(总题数:50,分数:50.00)1.下列函数的运行结果是main ( )int i=2,p;int j,k;j=i;k=+i;p=f(j,k);printf(“%d“,p); int f(int a,int b)int c;if(ab)c=1;else if(a=b)c=0;else c=-1;return(c);(分数:1.00)A.-1 B.1C.2D.编译出错,无法运行解析:解析 函数调用相当于 f(2,3),程序运算应得结果为“-1”。2.阅读下面程序,则执行后的结果是#include“st
20、dio.h“main()char str=“tomeetme“,*p;for(p=str;pstr+7;p+=2)putchar(*p);printf(“/n“); (分数:1.00)A.tomeetmeB.tmem C.oeteD.tome解析:解析 存放字符串的字符数组的名字就是这个字符串的首地址。本题的功能是对于字符串“tomeetme”进行选择式输出,从第一个字母开始,每输出一个字符即跳过一个。3.下列关于字符串的说法中错误的是(分数:1.00)A.在 C 语言中,字符串是借助于字符型一维数组来存放的,并规定以字符/0作为字符串结束标志B./0作为标志占用存储空间,计入串的实际长度 C
21、.在表示字符串常量的时候不需要人为在其末尾加入/0D.在 C 语言中,字符串常量隐含处理成以/0结尾解析:解析 /0作为标志占用存储空间,但是不计入串的实际长度。当给一个字符型指针赋值时,赋给这个指针的是这个字符串的地址。4.下面四个选项中,均是不正确的 8 进制数或 16 进制数的选项是(分数:1.00)A.016 0x8f 018B.0abc 017 0xaC.010 -0x11 0x16D.0a12 7ff -123 解析:解析 8 进制中,不可能包括 8 以上的数字,它的范围只在 07 之间,以 0 开头。同样,+六进制是以 0x 开头,数字在 09 和 af 之间。5.有以下程序#i
22、ncludestdlib.hstruct NODEint num;struct NODE*next;main()struct NODE*p,*q,*r;p=(struct NODE*)malloc(sizeof(struct NODE);q=(struct NODE*)malloc(sizeof(struct NODE);r=(struct NODE*)malloc(sizeof(struct NODE);p-num=10;q-num=20;r-num=30;p-next=q;q-next=r;printf(“%d/n“,p-num+q-next-num);程序运行后的输出结果是(分数:1.0
23、0)A.10B.20C.30D.40 解析:解析 该题中考查的是简单的单链表,下图就是赋完值后的示意图:容易看到 p-num=10,而 q-next 就是 r,所以 q-next-num=30,故答案为 40。*6.以下程序有错,错误原因是main()int*p,i;char*q,ch;p= p= scanf(“%c, p=(char*)malloc(1) scanf(“%c“,p);C.char *p *p=getchar( ); D.char *p,ch;p=*p=getchar( );解析:解析 本题考查了字符的输入函数 getchar 和利用 scanf 函数输入一个字符。用 scan
- 1.请仔细阅读文档,确保文档完整性,对于不预览、不比对内容而直接下载带来的问题本站不予受理。
- 2.下载的文档,不会出现我们的网址水印。
- 3、该文档所得收入(下载+内容+预览)归上传者、原创作者;如果您是本文档原作者,请点此认领!既往收益都归您。
下载文档到电脑,查找使用更方便
5000 积分 0人已下载
下载 | 加入VIP,交流精品资源 |
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 计算机 职业资格 二级 语言 笔试 293 答案 解析 DOC
