1、二级 C语言笔试 354及答案解析(总分:110.00,做题时间:90 分钟)一、B选择题/B(总题数:40,分数:80.00)1.执行以下的程序段后,m 的值是_。 int a23=1,2,3,4,5,6; int m,*p; P=(分数:2.00)A.4B.5C.3D.不确定2.以下各选项企图说明种新的类型名,其中正确的是_。(分数:2.00)A.typedef vi int;B.typedef V2=int;C.typedef int v3;D.lypedef v4:int3.以下程序运行后的输出结果是_。 int d=1; fun(int p) static int d=5;d+=p
2、printf(“%d,d“);retum d; main() int a=3;printf(“%d/n“,fun(a+fun(d) );(分数:2.00)A.699B.9C.61515D.66154.以下程序的输出结果是_。 main() int a=3; printf(“%d/n“,(a+=a-+a*a) ) (分数:2.00)A.-6B.1C.2D.-125.以下程序的输出结果是_。 main() int i,a10; for(i=9;i=0;i-)ai=1O-i; printf(“%d%d%d“,a2,a5,a8); (分数:2.00)A.258B.741C.852D.3696.SQL语
3、言又称为_。(分数:2.00)A.结构化定义语言B.结构化控制语言C.结构化查询语言D.结构化操纵语言7.以下程序的结果是_。 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.57C.200100D.758.以下程序的输出结果是_。 main() int a44=1,3,5,2,4,6,3,5,7 printf(“%d%d%d%d/n“,a03,a12,a21,a30); (分数:2.00)A.0650B.1470C.5430D.输出值不定9.
4、整型变量 X和 Y的值相等,且为非 0值,则以下选项中结果为 0的表达式是_。(分数:2.00)A.X|YB.X|YC.X #undef a printf(“%d“,a); (分数:2.00)A.200 100B.100 100C.100 200D.200 20011.在数据流图(DFD) 中,带有名字的箭头表示_。(分数:2.00)A.控制程序的执行顺序B.模块之间的调用关系C.数据的流向D.程序的组成成分12.若有以下说明和语句: struct stint n;char*ch; struct st a3=5,“abc“7,“def“,9“,ghk“),*p=a; 则值为 6的表达式是_。(
5、分数:2.00)A.p+-nB.p-n+C.(*.n+D.+Pn13.在说明语句 int*f()中,标识符 f代表的是_。(分数:2.00)A.个用于指向整型数据的指针变量B.个用于指向一维数组的行指针C.个用于指向函数的指针变量D.一个返回值为指针型的函数名14.设 x为 int型变量,执行以下语句,x=10;x+=x-=x-x;x 的值为_。(分数:2.00)A.10B.20C.30D.4015.下列不属于软件调试技术的是_。(分数:2.00)A.强行排错法B.集成测试法C.回溯法D.原因排除法16.栈和队列的共同点是_。(分数:2.00)A.都是先进后出B.都是先进先出C.只允许在端点处
6、插入和删除元素D.没有共同点17.以理程序的输出结果_。 main() char st20=“he11/O/t/“; printf(“%d%d/n“,str1en(st),sizeof(st); (分数:2.00)A.99B.520C.1320D.202018.在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是_。(分数:2.00)A.地址传递B.单向值传递C.由实参传绐形,再由形参传回实参D.传递方式由用户指定19.以下选项中,非法的字符常量是_。(分数:2.00)A.t/B./17C.“/n“D./xaa20.以下程序的输出结果是_。 #define M(x,y,z)x*y
7、+z main() int a=1,b=2,c=3; printf(“%d/n“,M(a+b,b+c,c+a); (分数:2.00)A.19B.17C.15D.1221.下面程序的输出结果为_。 #includestring.h main() charP17=“abc“=“ABC“.STR50=“xyz“; strcpy(str,strcat(p1,p2); printf(%s,str); (分数:2.00)A.xyzabcABCB.abcABCC.xyzabcD.xyzABC23.设 int型占 2个字节,则 unsigned int所能表示的数据范围是_。(分数:2.00)A.065535
8、B.-3276932767C.165536D.03276724.以下程序的输出结果是_。 structHAR int x,y;structHAR*p; main() h0.x=1;h0.y=2; h1.x=3;h1.y=4; h0.p= printf(“%d%d/n“,(h0.p-y); (分数:2.00)A.12B.23C.14D.3225.已知二叉树 BT的后后序遍历序列是 dabec,中序遍历序列是 debac,它的前序遍序列是_。(分数:2.00)A.cedbaB.acbedC.decabD.deabc26.以下函数值的类型是_。 fun(float x) float y; y=3*x
9、-4 return y; (分数:2.00)A.intB.不确定C.voidD.float27.以下数组定义中不正确的是_。(分数:2.00)A.inta23;B.int b3=0,1,2C.int c100100=0;D.int d3=1,2,1,2,3,1,2,3,4;28.下列叙述中正确的是_。(分数:2.00)A.C程序中注释部分可以出现在程序中任何合适的地方B.花括号“”和“”只能作为函数体的定界符C.构成 C程序的基本单位是函数,所有函数名都可以由用户命名D.分号是 C语句之间的分隔符,不是语句的部分29.下列叙述中,不属于软件需求规格说明书的作用的是_。(分数:2.00)A.便于
10、用户、开发人员进行理解和交流B.反映出用户问题的结构,可以作为软件开发工作的基础和依据C.作为确认测试和验收的依据D.便于开发人员进行需求分析30.以下程序输出正确的是_。 amovep(int *pint(*a) 3int n) 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*)malloc(100); amovep(p,a,3); printf(“%d%d/n“,p2p5;free(p); (分数:2.00)A.56B.25C.34D.程序错误31.在下列几种排序
11、方法中,要求内存量最大的是_。(分数:2.00)A.插入排序B.选择排序C.快速排序D.归并排序32.下面的程序执行后,文件 test.t中内容是_。 #inc1udestdio.h void fun(char*fname,char*st) FILE*myf;int i; myf=fopen(fname,“w“) for(i=0;istrlen(st);i+)fputc(stimyf); fdose(myf); main() fun(“test.t“new word“);fun(“test.t,“hello,“);(分数:2.00)A.hello,B.new wor1dhelloC.new w
12、orldD.hello,rld33.假定 int类型变量占用两个字节,若有定义:int x100,2,4;,则数组 x在内存中所占字节数是_。(分数:2.00)A.3B.6C.10D.2034.若有说明 int i,j=2,*p=,则能完成 i=j赋值功能的语句是_。(分数:2.00)A.i=*pB.*P=* strcpy(str1+strlen(str1)/2“es she“); pfinff(“%s/n“,p1); (分数:2.00)填空项 1:_48.以下程序输出的最后个值是U 【8】 /U int ff(int n) static int f=1; f=f*n return f; ma
13、in() int i; for(i=1;i=5:i+) printf(“%d、n“,ff(i); (分数:2.00)填空项 1:_49.下列程序的输出结果是U 【9】 /U。 main() int a=2,4,6,*prt= for(y=0;y3;y+) z=(*(ptr+yx)?*(ptr+y):x; printf(“%d/n“,z); (分数:2.00)填空项 1:_50.若有定义语句 char s100,d100;int j=0,i=0;且 s中已赋字符串,请填空以实现拷贝。 (注:不使用逗号表达式) whi1e()si)dj=U 【10】 /U:j+; dj=0;(分数:2.00)填空
14、项 1:_51.若有如下结构体说明: struct STRU int a,b;charc:double d; struct STRU*p1,*p2; 请填空,以完成对 t数组的定义,t 数组的每个元素为该结构体类型。U 【11】 /Ut20(分数:2.00)填空项 1:_52.下面的程序可对指定字符串中的字符串进行从大到小排序,请将程序填完整。 (注:程序采用了冒泡排序法) #includestdio.h #includestring.h main() char*str=“ABCDabcd“,temp; int n,i; n=strlen(str); while(n-1) for(i=0;in
15、;i+) if(stristri+l) temp=U 【12】 /U;stri=stri+l; U 【13】 /U=temp; printf(U 【14】 /U); (分数:6.00)填空项 1:_53.以下程序段打开文件后,先利用 fseek函数将文件位置指针定位在文件末尾,然后调用 ftell函数返回当前文件位置指针的具体位置,从而确定文件长度,请填空。 FILE*myf;longfl; myf=U 【15】 /U(“test.t“,“rb“); fseek(myf,(),SEEK_END) fl+ftell(myf); fclose(myf); printf(“%ld/n“,fl);(分
16、数:2.00)填空项 1:_二级 C语言笔试 354答案解析(总分:110.00,做题时间:90 分钟)一、B选择题/B(总题数:40,分数:80.00)1.执行以下的程序段后,m 的值是_。 int a23=1,2,3,4,5,6; int m,*p; P=(分数:2.00)A.4B.5 C.3D.不确定解析:评析;程序中定义了一个指向整型变量的指针变量,并对其赋值为二维整型数组 a的首元素的地址。p4等价于*(p+4),即二维数组 a中第四个元素的值,而 a是一个 2*3的二维数组,其第四个元素为 a11,即 5。2.以下各选项企图说明种新的类型名,其中正确的是_。(分数:2.00)A.t
17、ypedef vi int;B.typedef V2=int;C.typedef int v3; D.lypedef v4:int解析:评析 C 语言中可以使用 typedef来重新定义已有的数据类型,相当于数据类型取个别名。3.以下程序运行后的输出结果是_。 int d=1; fun(int p) static int d=5;d+=p printf(“%d,d“);retum d; main() int a=3;printf(“%d/n“,fun(a+fun(d) );(分数:2.00)A.699B.9C.61515 D.6615解析:评析 静态局部变量在编译时赋初值,即只赋初值次,在程序
18、运行时它已有初值。以后每次调用时不再重新赋初值而只是保留上次函数调用结束时的值,而对自动变量赋初值,不是在编译时进行的,而在函数调用时进行,每调用次函数重新给次初值,相当于执行次赋值语句。本题在程序开头定义了全局变量 d并赋初值 1,在被调函数 fun()中,定义了静态局部变量 d,初值为 5。在第次调用函数fun时,d 初值为 5,p 由主函数传递过来的值为 1,则 d=d+p=5+1=6,由于 d是静态局部变量,在函数调用结束后,它仍保留 d=6。再次调用 fun函数,d 的初值为 6,而由主函数传递的 p的值为 9,则此时d=d+p=6+9=15,最后打印输出 d的值并返回主函数。4.以
19、下程序的输出结果是_。 main() int a=3; printf(“%d/n“,(a+=a-+a*a) ) (分数:2.00)A.-6B.1C.2D.-12 解析:评析 赋值运算符的结合方向是自右至左,所以表达式 a+=a=a*a先运算最右边的 a*a得 9,再运算 a=a-9,即 a=3-9,所以此时 a的值由 3变成了-6,最后运算 a=a+(-6)=-12。5.以下程序的输出结果是_。 main() int i,a10; for(i=9;i=0;i-)ai=1O-i; printf(“%d%d%d“,a2,a5,a8); (分数:2.00)A.258B.741C.852 D.369解
20、析:评析 在本题运行时主要注意的是当 i=9时,ai=l0-9=1;ai=8 时,ai=10-8=2;i=7 时,ai=10-7=3;依此类推,直到 i=O时,ai=10-0=10;此时,i 的值已变为-1,判断 for的循环条件,不成立,然后输出 a2,a5,a8分别为 8,5,2。6.SQL语言又称为_。(分数:2.00)A.结构化定义语言B.结构化控制语言C.结构化查询语言 D.结构化操纵语言解析:评析 结构化查询语言(structured Query Language,简称 SQL)是集数据定义、数据操纵和数据控制功能于一体的数据库语言。7.以下程序的结果是_。 int a,b; vo
21、id 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解析:评析 全程变量是可以在子函数中对其值作改变,且它也可作为函数间的值传递。但当函数或子函数中定义了与全程变量名称相同的局部变量,则全程变量将被屏蔽。8.以下程序的输出结果是_。 main() int a44=1,3,5,2,4,6,3,5,7 printf(“%d%d%d%d/n“,a03,a12,a21,a30); (分数:2.00)A.0650 B.1470C.5430D.输出值不
22、定解析:评析 对未给出初始值的整数数组元素,被默认初始化为零。9.整型变量 X和 Y的值相等,且为非 0值,则以下选项中结果为 0的表达式是_。(分数:2.00)A.X|YB.X|YC.X #undef a printf(“%d“,a); (分数:2.00)A.200 100B.100 100C.100 200 D.200 200解析:评析 #define 宏名的有效范围为定义命令之后到本源文件结束,可以在程序中使用#undef 命令终止宏定义的作用域。本题由#undef 的作用,使 a的作用范围在#define a 100 到#undef a 之间,故答案为 C11.在数据流图(DFD) 中
23、,带有名字的箭头表示_。(分数:2.00)A.控制程序的执行顺序B.模块之间的调用关系C.数据的流向 D.程序的组成成分解析:评析 在数据流图中,用标有名字的箭头表示数据流。数据流可以从加工流向加工,也可以从加工流向文件或从文件流向加工,并且可以从外部实体流向系统或从系统流向外部实体。12.若有以下说明和语句: struct stint n;char*ch; struct st a3=5,“abc“7,“def“,9“,ghk“),*p=a; 则值为 6的表达式是_。(分数:2.00)A.p+-nB.p-n+C.(*.n+D.+Pn 解析:评析 根据结构变量的存储特点,p+l 意味着增加地址值
24、为结构体数组 a的个元素所占的字节数,即 P使 p由 a0指向 a1起始地址。本题+p-n 得到 p指向的结构体变量中成员 n的值使之加1。因为 p指向数组 a起始地址,p-n 的值为 5,再执行自加 l运行,结果为 6。13.在说明语句 int*f()中,标识符 f代表的是_。(分数:2.00)A.个用于指向整型数据的指针变量B.个用于指向一维数组的行指针C.个用于指向函数的指针变量D.一个返回值为指针型的函数名 解析:评析 返回指针值的函数,其般定义形式为:类型标识符 *函数名(参数表); 例如:int*f(x,y); 其中,f 是函数名,调用它以后能得到个指向整型数据的指针(地址),x,
25、y 是函数 f的形参。在 f的两侧为别为*运算符和()运算符,而()优先级高于*,因此 f先与()结合,显然是函数形式。这个函数前面有一个*,表示此函数是指针型函数(函数值是指针)。前面的 int表示返回的指针指向整型变量。14.设 x为 int型变量,执行以下语句,x=10;x+=x-=x-x;x 的值为_。(分数:2.00)A.10B.20 C.30D.40解析:评析 本题 x=l0,表达式“x+=x-=x-x;”的求解步骤如下:先进行 x-x-x 的运算,相当于 x=x-(x-x)=x=l0;再进行 x+=x的运算,即 x=x+x=20。15.下列不属于软件调试技术的是_。(分数:2.0
26、0)A.强行排错法B.集成测试法 C.回溯法D.原因排除法解析:评析 调试的关键在于推断程序内部的错误位置及原因。主要的调试方法有强行排错法、回溯法和原因排除法。16.栈和队列的共同点是_。(分数:2.00)A.都是先进后出B.都是先进先出C.只允许在端点处插入和删除元素 D.没有共同点解析:评析 栈和队列都是种特殊的操作受限的线性表,只允许在端点处进行插入和删除。二者的区别是栈是种“后进先出”的线性表;而队列是种“先进先出”的线性表。17.以理程序的输出结果_。 main() char st20=“he11/O/t/“; printf(“%d%d/n“,str1en(st),sizeof(s
27、t); (分数:2.00)A.99B.520 C.1320D.2020解析:评析 C 语言中字符串是以/O字符结束的,且 strlen()函数计算的是/O字符前的所有字符的个数。本题中 strlen(st)应为 5。数组定义以后系统就为其分配相应大小的内存空间,而不论其中有没有内容。sizeof()函数是计算变量或数组的所分配到的内存空间的大小。所以本题的 sizeof(st)为 20。18.在调用函数时,如果实参是简单变量,它与对应形参之间的数据传递方式是_。(分数:2.00)A.地址传递B.单向值传递 C.由实参传绐形,再由形参传回实参D.传递方式由用户指定解析:评析 C 语言函数中的参数
28、传递方式有传值与付址两种方式,传值方式是指将实参的值复制份传递给形参,而传址方式是指将实参的变量地址传递给形参,也就是实参的引用。19.以下选项中,非法的字符常量是_。(分数:2.00)A.t/B./17C.“/n“ D./xaa解析:评析 C 语言中字符常量是以单引号括起来的单个字符,或以“/”与三位八进制数值或两位十六进制数值代替单个字符。20.以下程序的输出结果是_。 #define M(x,y,z)x*y+z main() int a=1,b=2,c=3; printf(“%d/n“,M(a+b,b+c,c+a); (分数:2.00)A.19B.17C.15D.12 解析:评析 C 语
29、言的宏定义包括不带参数的宏定义与带参数的宏定义。本题为带参数的宏定义,其形式为:#define 宏名(形参表)字符串。本题的 M(aa=b,b+c,c+a)被字符串 a+b*b+c+c+a代替。21.下面程序的输出结果为_。 #includestring.h main() charP17=“abc“=“ABC“.STR50=“xyz“; strcpy(str,strcat(p1,p2); printf(%s,str); (分数:2.00)A.xyzabcABCB.abcABC C.xyzabcD.xyzABC解析:评析 strcpy(strl,s1):作用是将字符串 s1拷贝到字符数组 str
30、l中去。strcat(字符数组 1,字符数组 2):把字符串 2接到字符串 1的后面,结果放在字符数组 1中,函数调用后返回字符数组 1的地址。本题定义了三个字符数组 pl,p2,str,strcat(pl,p2)函数的作用是将字符串数组 p2接到字符串 p1的后面,结果放在字符数组 p1中,再通过 strcpy()函数将该字符串拷贝到 str数组中,原 str数组中的字符串 xyz被覆盖,因此打印输出字符串 str即可得到 abcABC。解析:评析 本题中的答案 A与 D都缺少“;”,而答案 C中,表达式是不能独立成为语句的,答案 B使用了 C语言的自减运算符它就相当于 DD-1,所以答案
31、B为赋值语句。23.设 int型占 2个字节,则 unsigned int所能表示的数据范围是_。(分数:2.00)A.065535 B.-3276932767C.165536D.032767解析:评析 本题 int型占 2个字节,即 16位 unsigned int所能表示的数据范围是 0(2 16-1),即065535。24.以下程序的输出结果是_。 structHAR int x,y;structHAR*p; main() h0.x=1;h0.y=2; h1.x=3;h1.y=4; h0.p= printf(“%d%d/n“,(h0.p-y); (分数:2.00)A.12B.23C.14
32、D.32 解析:评析 本题中是个含有两个结点的循环链表。C 语言中结构体的定义为:srtyct 结构体类型名成员项表;25.已知二叉树 BT的后后序遍历序列是 dabec,中序遍历序列是 debac,它的前序遍序列是_。(分数:2.00)A.cedba B.acbedC.decabD.deabc解析:评析 二叉树 BT的后序遍历序列为 dabec,故 BT的根结点为 c:而 BT的中序遍历序列是debac,即遍历序列中最后个结点为跟结点,说明 BT的右子树为空。由 BT的的后序遍历序列和中序遍历序列可知 BT的左子树(LST)的后序遍历序序列和序遍历序列分别为 dabe和 deba(树是递归定
33、义的):故LST的根结点是 e,在由 LST的中序遍历序列可知其左子树为 d。因此 BT的前序遍历序列为 cedba。26.以下函数值的类型是_。 fun(float x) float y; y=3*x-4 return y; (分数:2.00)A.int B.不确定C.voidD.float解析:评析 C 语言中如果函数前不加任何数据类型时,默认函数的类型为整型,函数的类型就是函数返回值的类型。27.以下数组定义中不正确的是_。(分数:2.00)A.inta23;B.int b3=0,1,2C.int c100100=0;D.int d3=1,2,1,2,3,1,2,3,4; 解析:评析 维
34、数组的定义方式为:类型说明符 数组名常量表式;选项 A符合此定义形式,正确;C语言中多维数组赋初值时可以部分赋值,也可以不指定除第维以外的其他维的大小,故选项 C正确;另外,如果对全部数组元素都赋初值,则定义数组时对第维的长度可以不指定,但第二锥的长度不能省,所以选项 B正确,而选项 D是错误的。28.下列叙述中正确的是_。(分数:2.00)A.C程序中注释部分可以出现在程序中任何合适的地方 B.花括号“”和“”只能作为函数体的定界符C.构成 C程序的基本单位是函数,所有函数名都可以由用户命名D.分号是 C语句之间的分隔符,不是语句的部分解析:评析 C 程序中注释部分用“/*”和“*/”括起来
35、,可以出现在程序中任何合适的地方;花括号“”和“”不仅可作为函数体的定界符,也可作为复合语句的定界符;构成 C程序的基本单位是函数;个语句必须在最后出现分号,分号是 C 语句中不可缺少的部分。29.下列叙述中,不属于软件需求规格说明书的作用的是_。(分数:2.00)A.便于用户、开发人员进行理解和交流B.反映出用户问题的结构,可以作为软件开发工作的基础和依据C.作为确认测试和验收的依据D.便于开发人员进行需求分析 解析:评析 软件需求规格说明书是需求分析阶段的最后成果,是软件开发中的重要文档之一。它不能方便开发人员进行需求分析。30.以下程序输出正确的是_。 amovep(int *pint(
36、*a) 3int n) 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*)malloc(100); amovep(p,a,3); printf(“%d%d/n“,p2p5;free(p); (分数:2.00)A.56 B.25C.34D.程序错误解析:评析 本题 main函数中定义了指针 p和二维数组 a,通过函数 amovep将数组的值存入指针 p所指向的存储单元中,a 的各元素分别为:a00=1,a01=3,a02=5,a20,a21=0,a22=0。通过 mal
37、lo()函数绐指针分配内存空间,free()函数用于释放指针变量所用内存空间。在主函数中通过 amovep(p,a,3)调用函数 amovep,使得实参 p与形参 p,实参数组 a与形参中指向数组的指针变量共用同存储空间。最后输出 p2,p5为 56。31.在下列几种排序方法中,要求内存量最大的是_。(分数:2.00)A.插入排序B.选择排序C.快速排序D.归并排序 解析:评析 快速排序的基本思想是,通过一趟排序将待排序记录分割成独立的两部分,其中部分记录的关键字均比另部分记录的关键字小,再分别对这两分记录继续进行排序,以达到整个序列有序;插入排序的基本操作是指将无序序列中的各元素依次插入到已
38、经有序的线性表中,从而得到一个新的序列;选择排序的基本思想是:扫描整个线性表,从中选出最小的元素,将它交换到表的最前面(这是它应有的位置),然后对剩下的子表采用同样的方法,直到表空为止;归并排序是将两个或两个以上的有序表组合成一个新的有序表。32.下面的程序执行后,文件 test.t中内容是_。 #inc1udestdio.h void fun(char*fname,char*st) FILE*myf;int i; myf=fopen(fname,“w“) for(i=0;istrlen(st);i+)fputc(stimyf); fdose(myf); main() fun(“test.t“
39、new word“);fun(“test.t,“hello,“);(分数:2.00)A.hello, B.new wor1dhelloC.new worldD.hello,rld解析:评析 C 语言中文件有文本文件与二进制文件,对文件的使用前必须先打开,打开方式有只读,写入、读写等方式。33.假定 int类型变量占用两个字节,若有定义:int x100,2,4;,则数组 x在内存中所占字节数是_。(分数:2.00)A.3B.6C.10D.20 解析:评析 当数组定义后,系统就为其分配内存空间,而不论其中有没有内容。因此,本题中数组x10不论是否为其元素初始化,它所分配的存储空间仍为 2*10=
40、20个字节。34.若有说明 int i,j=2,*p=,则能完成 i=j赋值功能的语句是_。(分数:2.00)A.i=*pB.*P=* strcpy(str1+strlen(str1)/2“es she“); pfinff(“%s/n“,p1); (分数:2.00)填空项 1:_ (正确答案:How does she)解析:评析 strcpy(strl,sl):字符串拷贝函数,作用是将字符串 sl拷贝到字符数组 strl中去。strlen(str):测试字符串 str的长度,函数的值为字符串中实际长度,不包括/0在内。本题中strlen(str l)的值为 13,则 strcpy(strl+s
41、trlen(strl)/2“es she“)相当于 strcpy(strl+6“es she“);,因此可得答案为 How does she。48.以下程序输出的最后个值是U 【8】 /U int ff(int n) static int f=1; f=f*n return f; main() int i; for(i=1;i=5:i+) printf(“%d、n“,ff(i); (分数:2.00)填空项 1:_ (正确答案:120)解析:评析 静态变量的类型说明符是 static,静态局部变量属于静态存储方式,它具有以下特点: 静态局部变量属于静态存储类别,在静态存储区内分配存储单元。在程序
42、整个运行期间都不释放。 对静态局部变量是在编译时赋初值的,即只赋初值次,在程序运行时它已有初值。以后每次调用函数时不再重新赋初值而只是保留上次函数调用结束时的值。 如在定义局部变量时不赋初值的话,则对静态局部变量来说,编译时自动赋初值 0(对数值型变量)或空字符(对字符变量)。 (注意:C 语言中非静态变量在定义时,系统并不会自动给它赋初值) 虽然静态局部变量在函数调用结束后仍然存在,但其他函数是不能引用它的。本题中函数的功能是:与 for语句一起求一个整数的阶乘。49.下列程序的输出结果是U 【9】 /U。 main() int a=2,4,6,*prt= for(y=0;y3;y+) z=
43、(*(ptr+yx)?*(ptr+y):x; printf(“%d/n“,z); (分数:2.00)填空项 1:_ (正确答案:6)解析:评析 条件运算符的优先级高于赋值运算符,因此本题先计算关系个表达式(*ptr+y)x)?(ptr+y):x的值,再赋绐变量 z,当 y=O 时,*(ptr+y)=2,而 x=8,(*(ptr+y)x)条件为真,则整个条件表达式的值为*(pry)=2,所以 z=2;当 y=1时*(ptr+y)=4, (*(ptr+y)x)条件为真,则整个条件表达式的值为*(ptr+y)=4,所以 z=4;当 y=2时,*(ptr+y)=6,*(ptr+y)x)条件为真,则整个
44、条件表达式的值为*(ptr+y)=6,所以 z=6;循环结束。因此输出 z的结果为 6。50.若有定义语句 char s100,d100;int j=0,i=0;且 s中已赋字符串,请填空以实现拷贝。 (注:不使用逗号表达式) whi1e()si)dj=U 【10】 /U:j+; dj=0;(分数:2.00)填空项 1:_ (正确答案:si+)解析:评析 本题中为了能实现字符串的拷贝,需要使字符数组 s从头到尾依次遍历其所有元素。本题应使用 i的自增后置来实现。51.若有如下结构体说明: struct STRU int a,b;charc:double d; struct STRU*p1,*p
45、2; 请填空,以完成对 t数组的定义,t 数组的每个元素为该结构体类型。U 【11】 /Ut20(分数:2.00)填空项 1:_ (正确答案:stmctSTRU)解析:评析 结构件类型是构造数据类型,是用户自己定义的种类型。结构件类型的定义:struct 结构体类型名 成员项表; 定义结构伸变量的的形式为:struct 结构体类型名变量 1,变量 2,其中变量包括;般变量、指针变量、数组变量等。52.下面的程序可对指定字符串中的字符串进行从大到小排序,请将程序填完整。 (注:程序采用了冒泡排序法) #includestdio.h #includestring.h main() char*str=“ABCDabcd“,temp; int n,i; n=strlen(str); while(n-1) for(i=0;in;i+) if(stri