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

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

1、二级 C 语言笔试 29 及答案解析(总分:80.00,做题时间:90 分钟)一、B选择题/B(总题数:50,分数:50.00)1.设 a、b 和 c 都是 int 型变量,且 a=3、b=4、c=5,则下面的表达式中,值为 0 的表达式是_。(分数:1.00)A.a main() int i,*p= for(i=0;i2;i+) if(i=0)aaii+1=*p+1; else +p; printf(“%d“,*p); 的输出是_。(分数:1.00)A.23B.26C.33D.363.下述关于数据库系统的叙述中正确的是_。(分数:1.00)A.数据库系统减少了数据冗余B.数据库系统避免了一切

2、冗余C.数据库系统中数据的一致性是指数据类型的一致D.数据库系统比文件系统能管理更多的数据4.设有以下定义和语句,输出的结果是(用 small 模式编译,指针变量 2 个字节)_。 struct date long *cat; struct date *next; double dog; too; printf(“%d“,sizeof(too);(分数:1.00)A.20B.16C.14D.125.若有以下定义和语句: int a=1,2,3,4,5,6,7,8,9,10,*p=a; 则值为 3 的表达式是_。(分数:1.00)A.p+=2,*(p+)B.P+=2,*+pC.P+=3,*p+D

3、.P+=2,+*p6.数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是_。(分数:1.00)A.控制流B.加工C.数据存储D.源和潭7.关系表中的每一横行称为一个_。(分数:1.00)A.元组B.字段C.属性D.码8.不能把字符串“Hello!“赋给数组 b 的语句是_。(分数:1.00)A.char b10=H,e,l,l,o,!;B.char b10=h,e,l,l,o,!;C.char b10;strcpy(b,“Hello!“);D.char b10=“Hello!“;9.以下程序段给数组所有的元素输入数据,请选择正确

4、答案填入。 #includestdio.h main() int a10,i=0; while(i10)scanf(“%d“,_); (分数:1.00)A.a+(i+)B.的输出为_。(分数:1.00)A.10B.11C.12D.语法错误11.下面程序的输出是_。 typedef union long x2; int y4; char z8; MYTYPE; MYTYPE them; mare() printf(“%d/n“,sizeof(them);(分数:1.00)A.32B.16C.8D.2412.下面程序的输出是_。 main() char *s=“12134211“; int v1=

5、0,v2=0,v3=0,v4=0,k; for (k=0;sk;k+) switch(sk) default:v4+; case1:v1+; case3:v3+; case2:v2+; printf(“v1=%d,v2=%d,v3=%d,v4=%d/n“,v1,v2,v3,v4); (分数:1.00)A.v1=4,v2=2,v3=1,v4=1B.v1=4,v2=9,v3=3,v4=1C.v1=5,v2=8,v3=6,v4=1D.v1=8,v2=8,v3=8,v4=813.fgetc 函数的作用是从指定文件读入个字符,该文件的打开方式必须是_。(分数:1.00)A.只读B.追加C.读或读写D.以

6、上均正确14.若有下面的说明和定义,则 sizeof(struct aa)的值是_。 struct aa int r1;double r2;float r3; union uuchar u15;long u22ua; mya;(分数:1.00)A.30B.29C.24D.2215.若执行下面程序时从键盘上输入 5, main() int x; scanf(“%d“, if(x+5)printf(“%d/n“,x); else printf(“%d/n“,x-); 则输出是_。(分数:1.00)A.7B.6C.5D.416.下面程序段中 c 的二进制值是_。 char a=3,b=6,c; c=

7、ab1;(分数:1.00)A.00001011B.00001111C.00011110D.0001110017.若有程序 fun(int a,int b) static int c=0; c+=a+b; rerurn c; main() int x=5,y=3,z=7,r; r=fun(y,x+y),z); r=fun(x,y); printf(“%d/n“,r); 上面程序的输出结果是_。(分数:1.00)A.23B.15C.19D.1818.以下程序运行后,输出结果是_。 main() char *d=“ab“,“cde“; printf(“%x“,d1); (分数:1.00)A.cdeB

8、.字符 c 的 AScII 码值C.字符 c 的地址D.出错19.下面程序输出的结果是_。 main() int i=5,j=9,x; x=(i=j?i:(j=7); printf(“/n%d,%d“,i,j); (分数:1.00)A.5,7B.5,5C.语法错误D.7,520.若 x 是整型变量,pb 是基类型为整型的指针变量,则正确的赋值表达式是_。(分数:1.00)A.pb= printf(“%d/n“,x=x1); 的输出是_。(分数:1.00)A.100B.160C.120D.6422.下列叙述中正确的是_。(分数:1.00)A.线性表是线性结构B.栈与队列是非线性结构C.线性链表是

9、非线性结构D.二叉树是线性结构23.一个良好的算法由下面的基本结构组成,但不包括_。(分数:1.00)A.顺序结构B.选择结构C.循环结构D.跳转结构24.请选出以下程序的输出结果_。 #includestdio.h sub(x,y,z) int x,y,*z; *z=y-x; main() int a,b,c; sub(10,5,sub(7,a,sub(a,b, printf(“%d,%d,%d/n“,a,b,c); (分数:1.00)A.5,2,3B.-5,-12,-7C.-5,-12,-17D.5,-2,-725.请选出正确的程序段_。(分数:1.00)A.int *p scanf(“%

10、d“,; B.int *s,k; *s=100; C.int *s,k; char *p,c; s= p= *p=a; D.int *s,k; char *p,e; s= p= s=p; *s=1; 26.下面程序在屏幕上的输出是_。 main() printf(“ab/b/bc“); (分数:1.00)A.ab/b/bcB.acC.abcD.abc27.字符(char)型数据在微机内存中的存储形式是_。(分数:1.00)A.反码B.补码C.EBCDIC 码D.ASCII 码28.算法的时间复杂度是指_。(分数:1.00)A.执行算法程序所需要的时间B.算法程序的长度C.算法执行过程中所需要的

11、基本运算次数D.算法程序中的指令条数29.在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是_。(分数:1.00)A.地址传递B.单向值传递C.由实参传递给形参,再由形参传递给实参D.传递方式由用户指定30.数据库设计包括两个方面的设计内容,它们是_。(分数:1.00)A.概念设计和逻辑设计B.模式设计和内模式设计C.内模式设计和物理设计D.结构特性设计和行为特性设计31.结构化程序设计主要强调的是_。(分数:1.00)A.程序的规模B.程序的易读性C.程序的执行效率D.程序的可移植性32.若要用下面的程序片段使指针变量 p 指向一个存储整型变量的动态存储单元 int *p p

12、=_malloc(sizeof(int); 则应填入_。(分数:1.00)A.intB.int*C.(*inD.(int*)33.设有如下程序 #includestdio.h main() int *k, *j,i=100; j= k= printf(“%d/n“”,*k); 上述程序的输出结果是_。(分数:1.00)A.运行错误B.100C.i 的地址D.j 的地址34.以下程序 #includestdio.h #includestring.h main() char*p1=“abc“,*p2=“ABC“,str50=“xyz“; strcpy(ar+2,strcat(p1,p2); pri

13、ntf(“%s/n“,str); 的输出是_。(分数:1.00)A.xyzabcABCB.zabeABCC.yzabcABCD.xyabcABC35.软件需求分析一般应确定的是用户对软件的_。(分数:1.00)A.功能需求B.非功能需求C.性能需求D.功能需求和非功能需求36.以下程序的输出结果是_。 #includestdio.h #define FUDGE(y) 2.84+y #define PR(a) printf(“%d“,(int)(a) #define PRINT1(a) PR(a);putchar(/n) main() int x=2; PRINT1(FUDGE(5)*x); (

14、分数:1.00)A.11B.12C.13D.1537.设有以下语句,其中不是对 a 数组元素的正确引用的是:_(其中 0i10) int a10=0,1,2,3,4,5,6,7,8,9,*p=a;(分数:1.00)A.ap-aB.*( printf(“k=%d,k=%o,k=%x/n“,k,k,k); (分数:1.00)A.k=11,k=12,k=11B.k=11,k=13,k=13C.k=11,k=013,k=0xbD.k=11,k=13,k=B41.有以下程序,程序运行后的输出结果是_。 int f(int b4) int i,j,s=0; for(j=0;j4;j+) i=j; if(i

15、2)i=3-j; s+=bij; return s; main() int a44=1,2,3,4,0,2,4,6,3,6,9,12,3,2,1,0; printf(“%d/n“,f(a); (分数:1.00)A.22B.11C.18D.1642.下面程序 main() int x=100, a=10, b=20, ok1=5, ok2=0; if(ab) if(b!=15) if(!ok1) x=1; else if(ok2)x=10; x=1; printf(“%d/n“,x); 的输出是_。(分数:1.00)A.-1B.0C.1D.不确定的值43.有以下程序: #includestdio

16、.h main() char c6; int i=0; for(;i6;ci=getchar(),i+);for(i=0;i6;i+)putchar(ci; printf(“/n“); 如果从键盘上输入: ab回车 c回车 def回车 则输出结果为_。(分数:1.00)A.a b c d e fB.a b c dC.ab c dD.abcdef44.下面程序的输出是_。 main() int x=3,y=6,a=0; while(x+!=(y-=1) a+=1; if(yx)break; printf(“x=%d,y=%d,a=%d/n“,x,y,a); (分数:1.00)A.x=4,y=4,

17、a=1B.x=5,y=5,a=1C.x=5,y=4,a=3D.x=5,y=4,a=145.请读程序: #includestdio.h main() int a;float b,c; scanf(“%2d%3t%4f“, printf(“/na=%d,b=%f,c=%f/n“,a,b,c); 若运行时从键盘上输入(图片),则上面程序的输出结果是_。(分数:1.00)A.a=98,b=765,c=4321B.a=10,b=432,c=8765C.a=98,b=765.000000,c=4321.000000D.a=98,b=765.0,c=4321.046.下面关于完全二叉树的叙述中,错误的是_。

18、(分数:1.00)A.除了最后层外,每层上的结点数均达到最大值B.可能缺少若干个左右叶子结点C.完全二叉树般不是满二叉树D.具有结点的完全二叉树的深度为log 2n+147.下列司用于 C 语言用户标识符的组是_。(分数:1.00)A.void define WORDB.a3_b3 _123 CarC.For -abc IFCaseD.2a DO sizeof48.以下程序运行后,输出结果为_。 main() int a23=1,3,5,7,9,11,*s2,*pp,*p; s0=a0,s1=a1; pp=s; p=(int*)malloc(sizeof(int); *pp=s11; p=*p

19、p; printf(“%d/n“,*p); (分数:1.00)A.1B.7C.9D.1149.以下程序的输出结果是_。 #includestdio.h #includesiring.h fun(char *w,int n) char t,*s1,*s2; s1=w;s2=w+n-1; while(s1s2) t=*s1+; *s1=*s2-; *s2=t; main() char *p; p=“1234567“; fun(p,strlen(p); puts(p); (分数:1.00)A.1234567B.7654321C.1711717D.717717150.以下对枚举类型名的定义中正确的是_

20、。(分数:1.00)A.enum a=one,two,three;B.enum aon=9,two=-1,three;C.enum a=“one“,“two“,“three“;D.enum a“one“,“two“,“three“;二、B填空题/B(总题数:15,分数:30.00)51.在先左后右的原则下,根据访问根结点的次序,二叉树的遍历可以分为三种:前序遍历、U 【1】 /U遍历和后序遍历。(分数:2.00)填空项 1:_52.结构化程序设计方法的主要原则可以概括为自顶向下、逐步求精、U 【2】 /U和限制使用goto 语句。(分数:2.00)填空项 1:_53.软件测试是保证软件质量的重

21、要手段,而软件测试的主要和重要的测试方法是通过测试数据和U 【3】 /U的设计来实现。(分数:2.00)填空项 1:_54.数据库系统的三级模式分别为U 【4】 /U模式、内部级模式与外部级模式。(分数:2.00)填空项 1:_55.数据字典是各类数据描述的集合,它通常包括 5 个部分,即数据项、数据结构、数据流、U 【5】 /U和处理过程。(分数:2.00)填空项 1:_56.下面程序的输出是U 【6】 /U。 main() int arr10,i,k=0; for(i=0;i10;i+) arri=i; fov(i=1;i4;i+) k+=arri+i; printf(“%d/n“,k);

22、(分数:2.00)填空项 1:_57.若 a=10,b=20,则表达式!(ab)的值是U 【7】 /U。(分数:2.00)填空项 1:_58.有以下程序 int fa(int x)return x*x; int fb(int x)retum x*x*x; int f(int(*f1)(),int(*f2)(),int x) return f2(x)-f1(x); main() int i;i=f(fa,fb,2);printf(“%d/n“,i); 程序运行后,输出结果是U 【8】 /U。(分数:2.00)填空项 1:_59.下面程序的输出是U 【9】 /U。 main() enum erne

23、m1=3,em2=1,em3; char *aa=“AA“,“BB“,“CC“,“DD“; printf(“%s%s%s/n“,aaem1,aaem2,aaem3); (分数:2.00)填空项 1:_60.若想通过以下输入语句使 a=5.0,b=4,c=3,则输入数据的形式应该是U 【10】 /U。 int b,c; float a; scanf(“%f,%d,c=%d“, dp=x*x-y*y; main() int a=4,b=3,c=5,d=6; t(a,b,c,d); printf(“%d%d/n“,c,d); (分数:2.00)填空项 1:_62.下面程序的输出结果是U 【12】 /

24、U。 char b=“ABCD“; main() char b30; strcpy( strcpy( strcpy( printf(“%s/n“,b); (分数:2.00)填空项 1:_63.有以下定义和语句,则 sizeof(a)的值是U 【13】 /U,而 sizeof(a.share)的值是U 【14】 /U。 struct date int day; int mouth; int year; union int share1; float share2; share; a;(分数:2.00)填空项 1:_64.下述函数用于统计一行字符中的单词个数,单词之间用空格分隔。 word_num

25、(str) char str; int i,num=0,word=0; fo(i=0;stri!=U 【15】 /U;i+) if(U 【16】 /U=)word=0; else if(word=0) word=1; U 【17】 /U; return(num); (分数:2.00)填空项 1:_65.有一个已排好序的数组,今输入一个数,要求按原来的顺序规律将它插入到数组中。算法是:假设排序顺序是从小到大,对输入的数,检查它在数组中哪个数之后,然后将比这个数大的数顺序后移一个位置,在空出的位置上将该数插入。请在程序中的空白处填上一条语句或一个表达式。 #define N 100 main()

26、float aN+1,x; int i,p; for(i=0;iN;i+) scanf(“%f“ scanf(“%f“, for(i=0,p=N;iN;i+) if(xai) U 【18】 /U; break; for(i=N-1;U 【19】 /U;i-) ai+1=ai; ap=x; for(i=0;U 【20】 /U;i+) printf(“%8.2f“,ai); if(i%5=0) printf(“/n“); (分数:2.00)填空项 1:_二级 C 语言笔试 29 答案解析(总分:80.00,做题时间:90 分钟)一、B选择题/B(总题数:50,分数:50.00)1.设 a、b 和

27、c 都是 int 型变量,且 a=3、b=4、c=5,则下面的表达式中,值为 0 的表达式是_。(分数:1.00)A.a main() int i,*p= for(i=0;i2;i+) if(i=0)aaii+1=*p+1; else +p; printf(“%d“,*p); 的输出是_。(分数:1.00)A.23 B.26C.33D.36解析:评析 观察题目,可以发现,*p= struct date *next; double dog; too; printf(“%d“,sizeof(too);(分数:1.00)A.20B.16C.14D.12 解析:评析 sizeof 函数计算已知类型所占

28、的字节数。结构体变量所占内存长度是各成员占的内存长度之和。指针变量占 2 个字节,所以 cat 和*next 各占 2 个字节;double 型占 8 个字节,故 too 共占 12 个字节。5.若有以下定义和语句: int a=1,2,3,4,5,6,7,8,9,10,*p=a; 则值为 3 的表达式是_。(分数:1.00)A.p+=2,*(p+) B.P+=2,*+pC.P+=3,*p+D.P+=2,+*p解析:评析 引用个数组元素,可以用:(1)下标法,如 ai形式:(2)指针法,如*(a+i)或*(p+i)。数组的下标从 0 开始,值为 3 的数组元素是 a2。B、C 的内容为 a3,

29、D 将 a2前自加,结果为 4。6.数据流图用于抽象描述一个软件的逻辑模型,数据流图由一些特定的图符构成。下列图符名标识的图符不属于数据流图合法图符的是_。(分数:1.00)A.控制流 B.加工C.数据存储D.源和潭解析:评析 数据流图从数据传递和加工的角度,来刻画数据流从输入到输出的移动变换过程。数据流图中的主要图形元素有:加工(转换)、数据流、存储文件(数据源)、源和潭。7.关系表中的每一横行称为一个_。(分数:1.00)A.元组 B.字段C.属性D.码解析:评析 在关系数据库中,关系模型采用二维表来表示,简称“表”。二维表是由表框架及表元组组成。在表框架中,按行可以存放数据,每行数据称为

30、元组。8.不能把字符串“Hello!“赋给数组 b 的语句是_。(分数:1.00)A.char b10=H,e,l,l,o,!;B.char b10=h,e,l,l,o,!; C.char b10;strcpy(b,“Hello!“);D.char b10=“Hello!“;解析:评析 在 C 语言中,大写字母和小写字母被认为是两个不同的字符,因此,“hello!”和“Hello!”是两个不同的字符串。9.以下程序段给数组所有的元素输入数据,请选择正确答案填入。 #includestdio.h main() int a10,i=0; while(i10)scanf(“%d“,_); (分数:1

31、.00)A.a+(i+) B.的输出为_。(分数:1.00)A.10B.11C.12D.语法错误 解析:评析 C 语言中有基本的算术运算符(+、-、*、/)还包括自增自减运算符(+、-),在 C 语言解析表达式时,它总是进行贪婪咀嚼,这样,该表达式就被解析为 i+i,显然该表达式不合 C 语言语法。11.下面程序的输出是_。 typedef union long x2; int y4; char z8; MYTYPE; MYTYPE them; mare() printf(“%d/n“,sizeof(them);(分数:1.00)A.32B.16C.8 D.24解析:评析 sizeof(x)是

32、一个标准 C 函数,它的返回值是 x 型的数据结构占用的内存字节数。题目中定义了一个共用体,共用体变量在内存中所占的长度等于最长的成员的长度。12.下面程序的输出是_。 main() char *s=“12134211“; int v1=0,v2=0,v3=0,v4=0,k; for (k=0;sk;k+) switch(sk) default:v4+; case1:v1+; case3:v3+; case2:v2+; printf(“v1=%d,v2=%d,v3=%d,v4=%d/n“,v1,v2,v3,v4); (分数:1.00)A.v1=4,v2=2,v3=1,v4=1B.v1=4,v2

33、=9,v3=3,v4=1C.v1=5,v2=8,v3=6,v4=1 D.v1=8,v2=8,v3=8,v4=8解析:评析 当 switch 后面括弧内的表达式的值与某一个 case 后面的常量的表达式的值相等时,就执行此 case 后面的语句,若所有的 case 中的常量表达式的值都没有与表达式的值匹配的,就执行 default后面的语句。13.fgetc 函数的作用是从指定文件读入个字符,该文件的打开方式必须是_。(分数:1.00)A.只读B.追加C.读或读写D.以上均正确 解析:评析 fgetc 函数是指从指定的文件读入一个字符,该文件必须是以读或读写方式打开的。fgetc函数的调用形式为

34、: ch=fgetc(fp);。14.若有下面的说明和定义,则 sizeof(struct aa)的值是_。 struct aa int r1;double r2;float r3; union uuchar u15;long u22ua; mya;(分数:1.00)A.30B.29C.24D.22 解析:评析 结构伸变量所占内存长度是各成员占的内存长度之和,每个成员分别占有自己的内存单元;共用体变量所占的内存长度等于最长的成员的长度。结构体变量 aa 中,成员 r1 占 2 个字节,r2 占 8 个字节,r3 占 4 个字节,共用体 ua 占 8 个字节,所以共占用 2+8+4+8=22 个

35、字节。15.若执行下面程序时从键盘上输入 5, main() int x; scanf(“%d“, if(x+5)printf(“%d/n“,x); else printf(“%d/n“,x-); 则输出是_。(分数:1.00)A.7B.6 C.5D.4解析:评析 根据 C 语言的语法,X+是在使用 x 之后,再将 x 的值加 1,在 if 语句中,x 的值为 5,条件不成立,执行 else 后面的语句,因为 x 的值已经加 1,为 6,所以打印结果为 6。16.下面程序段中 c 的二进制值是_。 char a=3,b=6,c; c=ab1;(分数:1.00)A.00001011B.00001

36、111 C.00011110D.00011100解析:评析 C 语言提供六种位运算符,按优先级由高到低的顺序分别为:取反()、左移()和右移()、按位与 ( c+=a+b; rerurn c; main() int x=5,y=3,z=7,r; r=fun(y,x+y),z); r=fun(x,y); printf(“%d/n“,r); 上面程序的输出结果是_。(分数:1.00)A.23 B.15C.19D.18解析:评析 static 声明的外部变量只限于被本文件引用,而不能被其他文件引用。用 static 来声明个变量的作用有:对局部变量用 static 声明,则为该变量分配的空间在整个程

37、序执行期间始终存在;全部变量用 static 声明,则该变量的作用域只限于本文件模块(即被声明的文件中)。调用第个fun,其两个实参的值为(3,5+3)与 7 即 8 与 7,在函数 fun 执行结束返回 15。第二次调用 fun 时,由于static 为静态类型,其值保留,执行 fun(5,3)后,其返回值为 23,故选 A。18.以下程序运行后,输出结果是_。 main() char *d=“ab“,“cde“; printf(“%x“,d1); (分数:1.00)A.cdeB.字符 c 的 AScII 码值C.字符 c 的地址 D.出错解析:评析 指针数组中的每一个元素都相当于一个指针变

38、量。一维指针数组的定义形式为:类型名 *数组名数组长度,在本题 main 函数中定义指针数组 d,它有两个元素,其初值分别是“ab”、“cde”的首地址。d1的值为“cde”的首地址。%x 是指以十六进制数形式输出整数。19.下面程序输出的结果是_。 main() int i=5,j=9,x; x=(i=j?i:(j=7); printf(“/n%d,%d“,i,j); (分数:1.00)A.5,7 B.5,5C.语法错误D.7,5解析:评析 条件表达式的一般形式为:表达式 1?表达式 2:表达式 3;先求解表达式 1,若为真则求解表达式 2;若表达式 1 的值为假,则求解表达式 3。本题中先

39、判断 i=j,不等,执行 j=7;然后执行x=7。故本题为 A。20.若 x 是整型变量,pb 是基类型为整型的指针变量,则正确的赋值表达式是_。(分数:1.00)A.pb= printf(“%d/n“,x=x1); 的输出是_。(分数:1.00)A.100B.160C.120D.64 解析:评析 是 C 语言中规定的左移运算符,例如,a=a2,这个语句即是将 a 的二进制数左移两位,左移一位相当于该数乘于 2,左移两位相当于该数乘以 2 的 2 次方。所以,x1=32*2=64。22.下列叙述中正确的是_。(分数:1.00)A.线性表是线性结构 B.栈与队列是非线性结构C.线性链表是非线性结

40、构D.二叉树是线性结构解析:评析 一般将数据结构分为两大类型:线性结构与非线性结构。线性表、栈与队列、线性链表都是线性结构,而二叉树是非线性结构。23.一个良好的算法由下面的基本结构组成,但不包括_。(分数:1.00)A.顺序结构B.选择结构C.循环结构D.跳转结构 解析:评析 1966 年,Bohra 和 Jacopini 提出了以下三种基本结构,用这三种基本结构作为表示个良好算法的基本单元:1、顺序结构;2、选择结构;3、循环结构。24.请选出以下程序的输出结果_。 #includestdio.h sub(x,y,z) int x,y,*z; *z=y-x; main() int a,b,

41、c; sub(10,5,sub(7,a,sub(a,b, printf(“%d,%d,%d/n“,a,b,c); (分数:1.00)A.5,2,3B.-5,-12,-7 C.-5,-12,-17D.5,-2,-7解析:评析 sub()函数的作用是将形参 y 和 x 的差赋给了 z 指向的那个内存地址,所以在 sub(10,5, B.int *s,k; *s=100; C.int *s,k; char *p,c; s= p= *p=a; D.int *s,k; char *p,e; s= p= s=p; *s=1; 解析:评析 本题的 A 和 B 犯了一个同样的错误,即指针变量 p 定义后并没有

42、指向具体的变量,因此不能进行赋值操作。另外,在选项 D 中,s 是 int 指针变量,p 是 char 型指针变量,所指向的内存单元所占用的字节数是不同的,因而不能将字符指针变量 p 的值赋给整型指针变量 s。26.下面程序在屏幕上的输出是_。 main() printf(“ab/b/bc“); (分数:1.00)A.ab/b/bcB.ac C.abcD.abc解析:评析 C 语言中允许使用种特殊形式的字符常量,就是以个“/”开头的字符序列,这样的字符称为“转文字符”。常用的转文字符有:/n,换行;/t,水平制表;/b,退格:/r,回车。27.字符(char)型数据在微机内存中的存储形式是_。

43、(分数:1.00)A.反码B.补码C.EBCDIC 码D.ASCII 码 解析:评析 将个字符常量放到一个字符变量中,实际上并不是把该字符本身放到内存单元中去,而是将该字符的 ASCII 码值放到存储单元中。28.算法的时间复杂度是指_。(分数:1.00)A.执行算法程序所需要的时间B.算法程序的长度C.算法执行过程中所需要的基本运算次数 D.算法程序中的指令条数解析:评析 所谓算法的时间复杂度,是指执行算法所需要的计算工作量。29.在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是_。(分数:1.00)A.地址传递B.单向值传递 C.由实参传递给形参,再由形参传递给实参D.传

44、递方式由用户指定解析:评析 C 语言以定,实参变量对形参变量的数据传递是“单向值传递”,只由实参传绐形参。在内存中,实参单元与形参单元是不同的单元。调用结束后,实参单元仍保留并维持原值。30.数据库设计包括两个方面的设计内容,它们是_。(分数:1.00)A.概念设计和逻辑设计 B.模式设计和内模式设计C.内模式设计和物理设计D.结构特性设计和行为特性设计解析:评析 数据库设计可分为概念设计与逻辑设计。概念设计的目的是分析数据间内在语义关联,在此基础上建立一个数据的抽象模型。逻辑设计的主要工作是将 ER 图转换为指定的 RDBMS 中的关系模型。31.结构化程序设计主要强调的是_。(分数:1.00)A.程序的规模B.程序的易读性 C.程序的执行效率D.程序的可移植性解析:评析 结构化程序设计主要强调的是结构化程序清晰易读,可理解性好,程序员能够进行逐步求精、程序证明和测试,以保证程序的正确性。32.若要用下面的程序片段使指针变量 p 指向一个存储整型变量的动态存储单元 int *p p=_malloc(sizeof(int); 则应填入_。(分数:1.00)A.intB.int*C.(*inD.(int*) 解析:评析 不论 p 是指向什么类型的指针变量,都可以通过强制类型转换的方法使之类型一致,强制

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

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

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