欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:1326390       资源大小:74.50KB        全文页数:13页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    1、二级 C 语言笔试 49 及答案解析(总分:96.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.以下程序的输出结果是_。 struct HAR int x,y;struct HAR *p;h2 main() h0.x=1;h0.y=2 h1.x=3;h1.y=4 h0.p=h1.p=h printf(“%d%d/n“,()h0.p)-x,(h1.p-y); (分数:2.00)A.12B.23C.14D.322.以下程序输出正确的是_ amovep(int *p,int (*a)3,int n) int i,j; for(i=0;in;i+) for(j=0;

    2、jn;j+) *p=aij;p+; main() int *p,a33=1,3,5, 2,4,6; p=(int*)mallox(100) amovep)p,a,3); printf(“%d%d/n“,p2,p5);free(p) (分数:2.00)A.56B.25C.34D.程序错误3.以下程序的输出结是_。 #include stdio.h main() int a=200; #define a 100 printf(“%d“,a); #undefa printf(%d“,a); (分数:2.00)A.200 100B.100 100C.100 200D.200 2004.下列不属于软件调

    3、试技术的是_。(分数:2.00)A.强行排错法B.集成测试法C.回溯法D.原因排除法5.以下数组定义中不正确的是_。(分数:2.00)A.int a23;B.int b3=0,1,2;C.int c100100=0;D.int d3=1,2,1,2,3,1,2,3,4;6.在计算面中,算法是指_。(分数:2.00)A.查询方法B.加工方祛C.解题方案的准确而完整的描述D.排序方法7.栈和队列的共同点是_。(分数:2.00)A.都是先进后出B.都是先进先出C.只允许在端点处插入和删除元素D.没有共同点8.设 a、b、c、d、mn 均为血型变量,且 a=5、b=6、c=7、d=8、m=2、n=2,

    4、则逻辑表达式(m=ab)(n=cd)运算后,n 的值为_。(分数:2.00)A.0B.1C.2D.39.下列叙述中正确的是_。(分数:2.00)A.C 程序中注释部分可以出现在程序中任伺合适的地方B.花括号“和“只能作为函数体的定界符C.构成 C 程序的基本单位是函数,所有函数名都可以由用户命名D.分号是 C 语句之间的分隔符,不是语句的部分10.以下合法的赋值语句是_。(分数:2.00)A.X=Y=100B.D-;C.X+YD.C=int(+)11.以下程序的结果是_。 int a,b; void fun() a=100;b=200; main() int a=5;b=7 fun(); pr

    5、intf(“%d%d/n“,a,b); (分数:2.00)A.100200B.57C.200100D.7512.下列叙述中,不属于软件需求规格说明书的作用的是_。(分数:2.00)A.便于用户、开发人员进行理解和交流B.反映出用户问题的结构,可以作为软件开发工作的基础和依据C.作为确认测试和验收的依据D.便于开发人员进行需求分析13.以下程序的输出结果是_。 main() int a=3; printf(“%/n“,(a+=a-=a*a); (分数:2.00)A.B.1C.2D.-1214.以下函数值的类型是_。 fun (float x) float y; y=3*x-4; return y

    6、; (分数:2.00)A.intB.不确定C.voidD.float15.以下各选项企图说明一种新的类型名,其中正确的是_。(分数:2.00)A.typedef v1 int;B.typedef v2=int;C.typedef int v3;D.typedef v4: int16.以下程序的输出结果是_。 main() char st20=“hello/0/t/“; printf(%d%d/n“,strlen(st),sizeof(st); (分数:2.00)A.99B.520C.1320D.202017.视图设计一般有 3 种设计次序,下列不属于视图设计的是_。(分数:2.00)A.自顶向

    7、下B.由外向内C.由内向外D.自底向上18.以下程序运行后的输出结果是_。 int d=1; fun(int p) printf(%d“,d);return d; main() int a=3; printf(“%/n“,fun(a+fun(d);(分数:2.00)A.699B.669C.61515D.661519.整型变量 X 和 Y 的值相等,且为非 0 值,则以下选项中结果为 0 的表达式是_。(分数:2.00)A.X|YB.X|YC.X (分数:2.00)A.19B.17C.15D.1224.下面的程序执行后,文件 test.t 中内容是_。 #includestdio.h void

    8、fun(clar *fname,char *st) FILE*myf;int i; myf=fopen(fname,“w“); for(i=0;istden(st);i+)fputc(sti,myf); fclose(myf); main() fun(“test.t“,“new world“); fur(“test.t“,“hello,“;(分数:2.00)A.hello,B.new worldhelloC.new worldD.hello,rld25.以下有 4 组用户标识符,其中合法的一组是_。(分数:2.00)A.FOR -sub CaseB.4d Do SizeC.f2 G3 IF a

    9、bcD.WoRD void define26.以下程序的输出结果是_。 main() int a44=1,3,5,2,4,6,3,5,7); Print(“%d%d%d%d/n“,a03,al2,a2 1,a30); (分数:2.00)A.0650B.1470C.5430D.输出值不定27.在数据流图(DFD)中,带有名字的箭头表示_。(分数:2.00)A.控制程序的执行顺序B.模块之间的调用关系C.数据的流向D.程序的组成成分28.SQL 语言又称为_。(分数:2.00)A.结构化定义语言B.结构化控制语言C.结构化查询语言D.结构化操纵语言29.已知二叉树 BT 的后序遍历序列是 dabe

    10、c,中序遍历序列是 debac,它的前序遍历序列是_。(分数:2.00)A.cedbaB.acbedC.decabD.deabc30.若有说明 int i,j=2, *P=,则能完成 i=j 赋值功能的语句是_。(分数:2.00)A.i=*p;B.*P2=*C.i=D.i=*p;31.若有以下说明和语句: struct stint n;char *ch; struct st a35,“abc“,7,“def“,9,“ghk“,*p=a 则值为 6 的表达式是_。(分数:2.00)A.p+-nB.p-n+C.(*.n+D.+p-n32.在下列几种排序方法中,要求内存量最大的是_。(分数:2.00

    11、)A.插入排序B.选择排序C.快速排序D.归并排序33.设 x 为 int 型变量,执行以下语句,X=10;X+=X-=X-X;X 的值为_。(分数:2.00)A.10B.20C.30D.4034.以下程序的输出结果是_。 main() int i,a10; for(i=9;i=0;i-)ai=10-i; print(“%d%d%d,a2,a5,a8); (分数:2.00)A.258B.741C.852D.36935.在设计程序时,应采纳的原则之一是_。(分数:2.00)A.程序结构应有助于读者理解B.不限制 goto 语句的使用C.减少或取消注解行D.程序越短越好二、B填空题/B(总题数:1

    12、3,分数:26.00)36.实现算法所需的存储单元多少和算法的工作量大小分别为算法的U 【1】 /U。(分数:2.00)填空项 1:_37.数据结构包括数据的逻辑结构、数据的U 【2】 /U以及对数据的操作运算。(分数:2.00)填空项 1:_38.一个类可以从直接或间接的祖先中继承所有属性和方法。采用这个方法提高了软件的U 【3】 /U。(分数:2.00)填空项 1:_39.面向对象的模型中,最基本的概念是对象和U 【4】 /U。(分数:2.00)填空项 1:_40.软件维护活动包括以下几类:改正性维护、适应性维护、U 【5】 /U维护和预防性维护o(分数:2.00)填空项 1:_41.设

    13、Y 是 int 型变量,请写出判断 Y 为奇数的关系表达式U 【6】 /U。(分数:2.00)填空项 1:_42.以下程序的输出是U 【7】 /U。 main() char str1=“How do you do“,*pl=str1; strcpy(str1+strlen(str1)/2,“es she“); intf(“%s/n“,p1);(分数:2.00)填空项 1:_43.以下程序输出的最后一个值是U 【8】 /U。 int ff(int n) static int f=1; f=f*n; retum f; main() int i; for(i=1;i=5;i+) printf(“%d

    14、/n“,ff(i)i (分数:2.00)填空项 1:_44.下列程序的输出结果是U 【9】 /U。 main() int a=2,4,6,*ptr= for(y=0;y3;y+) z=(*(ptr+y)x)?*(ptr+y):x; print f(“%d/n“,z); (分数:2.00)填空项 1:_45.若有定义语句 char s100,d100;int j=0,i=0;且 s 中已赋字符串,请填空以实现拷贝。 (注:不使用逗号表达式) while(si)(dj=U 【10】 /U;j+; dj=0;(分数:2.00)填空项 1:_46.若有如下结构体说明: struct STRU int

    15、a,b;char c:double d; stmct STRU*p1,*p2; ; 请填空,以完成对 t 数组的定义,t 数组的每个元素为该结构体类型。U 【11】 /Ut20(分数:2.00)填空项 1:_47.下面的程序可对指定字符串进行从大到小排序,请将程序填完整。 (注:程序采用了冒泡排序算法) #includestdio.h #includestring.h main() char*str=“ABCDabcd“,temp; int n,i; n=strlen(str); while(n-1) for(i=0;in;i+) if(stristri+1) temp=U 【12】 /U;s

    16、tri=stri+1; U【13】 /U=temp; printf(U 【14】 /U); (分数:2.00)填空项 1:_48.以下程序段打开文件后,先利用 fseek 函数将文件位置指针定位在文件末尾,然后调用删函数返回当前文件位置指针的具体位置,从而确定文件长度,请填空。 FILE*myf;long fl; myf=U 【15】 /U(“test.t“,“rb“); fseek(myf,(),SEEK_END);fl+ftell(myf); fclose(myf); printf(“%d/n“,fl);(分数:2.00)填空项 1:_二级 C 语言笔试 49 答案解析(总分:96.00,

    17、做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.以下程序的输出结果是_。 struct HAR int x,y;struct HAR *p;h2 main() h0.x=1;h0.y=2 h1.x=3;h1.y=4 h0.p=h1.p=h printf(“%d%d/n“,()h0.p)-x,(h1.p-y); (分数:2.00)A.12B.23C.14D.32 解析:评析 本题中是一个含有两个结点的循环链表。 C 语言中结构体的定义为: struct 结构体类型名 成员项表; ;2.以下程序输出正确的是_ amovep(int *p,int (*a)3,int n)

    18、 int i,j; for(i=0;in;i+) for(j=0;jn;j+) *p=aij;p+; main() int *p,a33=1,3,5, 2,4,6; p=(int*)mallox(100) amovep)p,a,3); printf(“%d%d/n“,p2,p5);free(p) (分数:2.00)A.56 B.25C.34D.程序错误解析:评析 本题 main 函数中定义了指针 p 和二维数组 a,通过函数 amovep 将数组的值存入指针 p 所指向的存储单元中,a 的各元素分别:a00=1,a01=3,a01=3,a02=5,a12=2,a11=4,a12=6,a20=0

    19、,a21=0,a22=0。通过 malloc()函数给指针分配内存空间,free()函数用于释放指针变量所用内存空间。在主函数中通过 amovep(p,a,3)调用函数 amovep,使得实参p 与形参 P,实参数组 a 与形参中指向数组的指针变量共用同一存储空间。最后输出 p2,p5为 56。3.以下程序的输出结是_。 #include stdio.h main() int a=200; #define a 100 printf(“%d“,a); #undefa printf(%d“,a); (分数:2.00)A.200 100B.100 100C.100 200 D.200 200解析:评

    20、析 #define 宏名的有效范围为定义命令之后到本源文件结束,可以在程序中使用#undef 命令终止宏定义的作用域。本题由于#undef 的作用,使 a 的作用范围在#define a 100 到#undefa 之间,故答案为 C。4.下列不属于软件调试技术的是_。(分数:2.00)A.强行排错法B.集成测试法 C.回溯法D.原因排除法解析:评析 调试的关键在于推断程序内部的错误位置及原因。主要的调试方法有强行排错法、回溯法和原因排除法。5.以下数组定义中不正确的是_。(分数:2.00)A.int a23;B.int b3=0,1,2;C.int c100100=0;D.int d3=1,2

    21、,1,2,3,1,2,3,4; 解析:评析 一维数组的定义方式为: 类型说明符 数组名常量表达式; 选项 A 符合此定义形式,正确;C 语言中多维数组赋初值时可以部分赋值,也可以不指定除第一维以外的其他维的大小,故选项 C 正确;另外,如果对全部数纪元素都赋初值,则定义数组时对第一维的长度可以不指定,但第二锥的长度不能省,所以选项 B 正确,而选项 D 是错误的。6.在计算面中,算法是指_。(分数:2.00)A.查询方法B.加工方祛C.解题方案的准确而完整的描述 D.排序方法解析:评析 计算机算法是指解题方案的准确而完整的描述,它有以下几个基本特征:可行性、确定性、有穷性和拥有足够的情报。7.

    22、栈和队列的共同点是_。(分数:2.00)A.都是先进后出B.都是先进先出C.只允许在端点处插入和删除元素 D.没有共同点解析:评析 栈和队列都是一种特殊的操作受限的线性表,只允许在端点处进行插入和删除。二者的区别是:栈是一种“后进先出”的线性表;而队列是一种“先进先出”的线性表。8.设 a、b、c、d、mn 均为血型变量,且 a=5、b=6、c=7、d=8、m=2、n=2,则逻辑表达式(m=ab)(n=cd)运算后,n 的值为_。(分数:2.00)A.0 B.1C.2D.3解析:评析 C 语言中比较表达式的运算结果为 0 或 1。0 代表不成立,1 表示成立。9.下列叙述中正确的是_。(分数:

    23、2.00)A.C 程序中注释部分可以出现在程序中任伺合适的地方 B.花括号“和“只能作为函数体的定界符C.构成 C 程序的基本单位是函数,所有函数名都可以由用户命名D.分号是 C 语句之间的分隔符,不是语句的部分解析:评析 C 程序中注释部分用“/*”和“*/”括起来,可以出现在程序中任何合适的地方;花括号“”和“”不仅可作为函数体的定界符,也可作为复合语句的定界符;构成 C 程序的基本单位是函数;一个语句必须在最后出现分号,分号是 C 语句中不可缺少的部分。10.以下合法的赋值语句是_。(分数:2.00)A.X=Y=100B.D-; C.X+YD.C=int(+)解析:评析 本题中的答案 A

    24、 与 D 都缺少“;”,而答案 C 中,表达式是不能独立成为语句的,答案 B使用了 C 语言的自减运算符它就相当于 D=D-I,所以答案 B 为一赋值语句。11.以下程序的结果是_。 int a,b; void fun() a=100;b=200; main() int a=5;b=7 fun(); printf(“%d%d/n“,a,b); (分数:2.00)A.100200B.57 C.200100D.75解析:评析 全程变量是可以在子函数中对其值作改变,且它也可作为函数间的值传递。但当函数或子函数中定义了与全程变量名称相同的局部变量,则全程变量将被屏蔽。12.下列叙述中,不属于软件需求规

    25、格说明书的作用的是_。(分数:2.00)A.便于用户、开发人员进行理解和交流B.反映出用户问题的结构,可以作为软件开发工作的基础和依据C.作为确认测试和验收的依据D.便于开发人员进行需求分析 解析:评析 软件需求规格说明书是需求分析阶段的最后成果,是软件开发中的重要文档之一。它不能方便开发人员进行需求分析。13.以下程序的输出结果是_。 main() int a=3; printf(“%/n“,(a+=a-=a*a); (分数:2.00)A.B.1C.2D.-12 解析:评析 赋值运算符的结合方向是自右至左,所以表达式 a+a-=a*a 先运算最右边的 a*a 得 9,再运算 a=a-9,即

    26、a=3-9,所以此时 a 的值由 3 变成了-6,最后运算 a=a+(-6),即 a-(-6)+(-6)=-12。14.以下函数值的类型是_。 fun (float x) float y; y=3*x-4; return y; (分数:2.00)A.int B.不确定C.voidD.float解析:评析 C 语言中如果函数前不加任何数据类型时,默认函数的类型为整型,函数的类型就是函数返回值的类型。15.以下各选项企图说明一种新的类型名,其中正确的是_。(分数:2.00)A.typedef v1 int;B.typedef v2=int;C.typedef int v3; D.typedef v

    27、4: int解析:评析 C 语言中可以使用 typedef 来重新定义已有的数据类型,相当于为数据类型取个别名。16.以下程序的输出结果是_。 main() char st20=“hello/0/t/“; printf(%d%d/n“,strlen(st),sizeof(st); (分数:2.00)A.99B.520 C.1320D.2020解析:评析 C 语言中字符串是以/0字符结束的,且 strlen()函数计算的是/0字符前的所有字符的个数。本题中 strlen(st)应为 5。数组定义以后系统就为其分配相应大小的内存空间,而不论其中有没有内容。sizeof()函数是计算变量或数组的所分

    28、配到的内存空间的大小。所以本题的 sizeof(st)为 20。17.视图设计一般有 3 种设计次序,下列不属于视图设计的是_。(分数:2.00)A.自顶向下B.由外向内 C.由内向外D.自底向上解析:评析 视图设计一般有 3 种设计次序,它们分别是自顶向下、自底向上和由内向外,它们又为视图设计提供了具体的操作方法,设计者可根据实际情况灵活掌握,可以单独使用也可混合使用。18.以下程序运行后的输出结果是_。 int d=1; fun(int p) printf(%d“,d);return d; main() int a=3; printf(“%/n“,fun(a+fun(d);(分数:2.00

    29、)A.699B.669C.61515 D.6615解析:评析 静态局部变量在编译时赋韧值,即只赋初值一次,在程序运行时它已有初值。以后每次调用时不再重新赋韧值而只是保留上次函数调用结束时的值,而对自动变量赋初值,不是在编译时进行的,而在函数调用时进行,每调用次函数重新给一次初值,相当于执行一次赋值语句。 本题在程序开头定义了全局变量 d 并赋初值 1,在被调函数 fun()中,定义了静态局部变量 d,初值为 5。在第一次调用函数fun 时,d 初值为 5,p 由主函数传递过来的值为 1,则 d=d+p=5+1=6,由于 d 是静态局部变量,在函数调用结束后,它仍保留 d=6。再次调用 fun

    30、函数,d 的初值为 6,而由主函数传递的 p 的值为 9,则此时d=d+p=6+9=15,最后打印输出 d 的值井返回主函数。19.整型变量 X 和 Y 的值相等,且为非 0 值,则以下选项中结果为 0 的表达式是_。(分数:2.00)A.X|YB.X|YC.X (分数:2.00)A.19B.17C.15D.12 解析:评析 C 语言的宏定义包括不带参数的宏定义与带参数的宏定义。本题为带参数的宏定义,其形式为: #define 宏名(形参表)字符串 本题的 M(a+b,b+c,c+a)被字符串 a+b*b+c+c+a 代替。24.下面的程序执行后,文件 test.t 中内容是_。 #inclu

    31、destdio.h void fun(clar *fname,char *st) FILE*myf;int i; myf=fopen(fname,“w“); for(i=0;istden(st);i+)fputc(sti,myf); fclose(myf); main() fun(“test.t“,“new world“); fur(“test.t“,“hello,“;(分数:2.00)A.hello, B.new worldhelloC.new worldD.hello,rld解析:评析 C 语言中文件有文本文件与二进制文件,对文件的使用前必须先打开,打开方式有只读、写入、读写等方式。25.

    32、以下有 4 组用户标识符,其中合法的一组是_。(分数:2.00)A.FOR -sub CaseB.4d Do SizeC.f2 G3 IF abc D.WoRD void define解析:评析 C 语言的标识符的定义为:以字母或下划线开头的由字母、数字字符、下划线组成的字符串。而且标识符不能与关键字相同。26.以下程序的输出结果是_。 main() int a44=1,3,5,2,4,6,3,5,7); Print(“%d%d%d%d/n“,a03,al2,a2 1,a30); (分数:2.00)A.0650 B.1470C.5430D.输出值不定解析:评析 对未给出初始值的整数数组元素,被

    33、默认初始化为零。27.在数据流图(DFD)中,带有名字的箭头表示_。(分数:2.00)A.控制程序的执行顺序B.模块之间的调用关系C.数据的流向 D.程序的组成成分解析:评析 在数据流图中,用标有名字的箭头表示数据流。数据流可以从加工流向加工,也可以从加工流向文件或从文件流向加工,并且可以从外部实体流向系统或从系统流向外部实体。28.SQL 语言又称为_。(分数:2.00)A.结构化定义语言B.结构化控制语言C.结构化查询语言 D.结构化操纵语言解析:评析 结构化查询语言(Structured Query Language,简称 SQL)是集数据定义、数据操纵和数据控制功能于一体的数据库语言。

    34、29.已知二叉树 BT 的后序遍历序列是 dabec,中序遍历序列是 debac,它的前序遍历序列是_。(分数:2.00)A.cedba B.acbedC.decabD.deabc解析:评析 二叉树 BT 的后序遍历序列为 dabec,故 BT 的根结点为 C;而 BT 的中序遍历序列是debac,即遍历序列中最后一个结点为跟结点,说明 BT 的右子树为空。由 BT 的后序遍历序列和中序遍历序列可知 BT 的左子树(LST)的后序遍历序列和中序遍历序列分别为 dabe 和 deba(树是递归定义的):故LST 的根结点是 e,在由 LST 的中序遍历序列可知其左子树为 d。因此 BT 的前序遍

    35、历序列为 cedba。30.若有说明 int i,j=2, *P=,则能完成 i=j 赋值功能的语句是_。(分数:2.00)A.i=*p;B.*P2=* C.i=D.i=*p;解析:评析 指针是一种用来存放变量地址的特殊变量。本题中指针变量 p 用于存放整型变量 i 的地址,改变*p 的值即为改变 i 的值。又因为“char *ch; struct st a35,“abc“,7,“def“,9,“ghk“,*p=a 则值为 6 的表达式是_。(分数:2.00)A.p+-nB.p-n+C.(*.n+D.+p-n 解析:评析 根据结构变量的存储特点,p+1 意味着增加地址值为结构体数组 a 的一个

    36、元素所占的字节数,即 p+使 p 由 a0指向 a1起始地址。本题+p-n 得到 p 指向的结构体变量中成员 n 的值使之加1。因为 p 指向数组 a 起始地址,p-n 的值为 5,再执行自加 1 运行,结果为 6。32.在下列几种排序方法中,要求内存量最大的是_。(分数:2.00)A.插入排序B.选择排序C.快速排序D.归并排序 解析:评析 快速排序的基本思想是,通过一趟排序将待排序记录分割成独立的两部分,其中一部分记录的关键字均比另一部分记录的关键字小,再分别对这两部分记录继续进行排序,以达到整个序列有序;插入排序的基本操作是指将无序序列中的各元素依次插入到已经有序的线性表中,从而得到一个

    37、新的序列;选择排序的基本思想是:扫描整个线性表,从中选出最小的元素,将它交换到表的前面(这是它应有的位置),然后对剩下的子表采用同样的方法,直到表空为止;归并排序是将两个或两个以上的有序表组合成一个新的有序表。33.设 x 为 int 型变量,执行以下语句,X=10;X+=X-=X-X;X 的值为_。(分数:2.00)A.10B.20 C.30D.40解析:评析 本题 x=10,表达式“x+=x-=x-x;”的求解步骤如下:先进行 x-=x-x 的运算,相当于 x=x-(x-x)=x=10;再进行 x+=x 的运算,即 x=x+x=20。34.以下程序的输出结果是_。 main() int i

    38、,a10; for(i=9;i=0;i-)ai=10-i; print(“%d%d%d,a2,a5,a8); (分数:2.00)A.258B.741C.852 D.369解析:评析 在本题运行时主要注意的是当 i=9 时,ai=10-9=1:i=8 时,ai=10-8=2;i=7 时,ai=10-7=3;依此类推,直到 i=0 时,ai=10-0=10:此时,i 的值已变为-1,判断 for 的循环条件,不成立,然后输出 a2,a5,a8分别为 8,5,2。35.在设计程序时,应采纳的原则之一是_。(分数:2.00)A.程序结构应有助于读者理解 B.不限制 goto 语句的使用C.减少或取消注

    39、解行D.程序越短越好解析:评析 滥用 goto 语句将使程序流程无规律,可读性差;添加的注解行有利于对程序的理解,不应减少或取消;程序的长短要依照实际需要而定,并不是越短越好。二、B填空题/B(总题数:13,分数:26.00)36.实现算法所需的存储单元多少和算法的工作量大小分别为算法的U 【1】 /U。(分数:2.00)填空项 1:_ (正确答案:空间复杂度和时间复杂度)解析:评析 算法的复杂性是指对一个在有限步骤内终止算法和所需存储空间大小的估计。算法所需存储空间大小是算法的空间复杂性,算法的计算量是算法的时间复杂性。37.数据结构包括数据的逻辑结构、数据的U 【2】 /U以及对数据的操作

    40、运算。(分数:2.00)填空项 1:_ (正确答案:存储结构)解析:评析 数据结构包括 3 个方面,即数据的逻辑结构、数据的存储结构及对数据的操作运算。38.一个类可以从直接或间接的祖先中继承所有属性和方法。采用这个方法提高了软件的U 【3】 /U。(分数:2.00)填空项 1:_ (正确答案:可重用性)解析:评析 继承的优点:相似的对象可以共享程序代码和数据结构,从而大大减少了程序中的冗余,提高软件的可重用性。39.面向对象的模型中,最基本的概念是对象和U 【4】 /U。(分数:2.00)填空项 1:_ (正确答案:类)解析:评析 面向对象模型中,最基本的概念是对象和类。对象是现实世界中实体

    41、的模型化;将属性集和方法集相同的所有对象组合在一起,可以构成一个类。40.软件维护活动包括以下几类:改正性维护、适应性维护、U 【5】 /U维护和预防性维护o(分数:2.00)填空项 1:_ (正确答案:完善性)解析:评析 软件维护活动包括以下几类:改正性维护、适应性维护、完善性维护和预防性维护。完善性维护是指为了满足用户对软件提出的新功能与性能要求,需要修改或再开发软件,以扩充软件功能、增强软件性能、改进加工效率、提高软件的可维护性。41.设 Y 是 int 型变量,请写出判断 Y 为奇数的关系表达式U 【6】 /U。(分数:2.00)填空项 1:_ (正确答案:Y%2=1 或 Y%2!=0

    42、)解析:评析 判断变量是否为奇数可以用变量与 2 取模,判断结果是为 1 或下为 0。本题具体做法如下:Y%2=1 或 Y%2!=0。42.以下程序的输出是U 【7】 /U。 main() char str1=“How do you do“,*pl=str1; strcpy(str1+strlen(str1)/2,“es she“); intf(“%s/n“,p1);(分数:2.00)填空项 1:_ (正确答案:How does she)解析:评析 strcpy(str1,s1):字符串拷贝函数,作用是将字符串 s1 拷贝到字符数组 str1 中去。strlen(str):测试字符串 str

    43、的长度,函数的值为字符串中实际长度,不包括/0在内。本题中strlen(strl)的值为 13,则 strcpy(strl+strlen(strl)/2,“es she“);相当于 strqoy(strl+6,“es she“);因此可得答案为 How does she。43.以下程序输出的最后一个值是U 【8】 /U。 int ff(int n) static int f=1; f=f*n; retum f; main() int i; for(i=1;i=5;i+) printf(“%d/n“,ff(i)i (分数:2.00)填空项 1:_ (正确答案:120)解析:评析 静态变量的类型说

    44、明符是 static,静态局部变量属于静态存储方式,它具有以下特点: 静态局部变量属于静态存储类别,在静态存储区内分配存储单元。在程序整个运行期间都不释放。 对静态局部变量是在编译时赋初值的,即只赋初值一次,在程序运行时它已有初值。以后每次调用函数时不再重新赋初值而只是保留上次函数调用结束时的值。 如在定义局部变量时不赋初值的话,则对静态局部变量来说,编译对自动赋初值 0(对数值型变量)或空字符(对字符变量)。(注意:C 语言中的非静态变量在定义时,系统并不会自动给它赋初值) 虽然静态局部变量在函数调用结束后仍然存在,但其他函数是不能引用它的。 本题中函数的功能是:与 for 语句一起求一个整数的阶乘。44.下列程序的输出结果是U 【9】 /U。 main() int a=2,4,6,*ptr= for(y=0;y3;y+) z=(*(ptr+y)x)?*(ptr+y):x; print f(“%d/n“,z); (分数:2.00)填空项 1:_ (正确答案:6)解析:评析 条件运算符的优先级高于赋值运算符,因此本题先计算关系表达式(*ptr+


    注意事项

    本文(【计算机类职业资格】二级C语言笔试49及答案解析.doc)为本站会员(sofeeling205)主动上传,麦多课文档分享仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文档分享(点击联系客服),我们立即给予删除!




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开