1、2007 年 9月国家二级( C语言)笔试真题试卷及答案与解析 1 软件是指 ( A)程序 ( B)程序和文档 ( C)算法加数据结构 ( D)程序、数据与相关文档的完整集合 2 软件调试的目的是 ( A)发现错误 ( B)改正错误 ( C)改善软件的性能 ( D)验证软件的正确性 3 在面向对象方法中,实现信息隐蔽是依靠 ( A)对象的继承 ( B)对象的多态 ( C)对象的封装 ( D)对象的分类 4 下列叙述中,不符合良好程序设计风格要求的是 ( A)程序的效率第一,清晰第二 ( B)程序的 可读性好 ( C)程序中要有必要的注释。 ( D)输入数据前要有提示信息 5 下列叙述中正确的是
2、 ( A)程序执行的效率与数据的存储结构密切相关 ( B)程序执行的效率只取决于程序的控制结构 ( C)程序执行的效率只取决于所处理的数据量 ( D)以上三种说法都不对 6 下列叙述中正确的是 ( A)数据的逻辑结构与存储结构必定是一一对应的 ( B)由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构 ( C)程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线性结构 ( D)以上三种说法都不对 7 冒泡排序在最坏情况下的比较次数是 ( A) n(n+1)/2 ( B) nlog2n ( C) n(n-1)/2 ( D) n/2 8 一棵二叉树中共有 70个叶
3、子结点与 80个度为 1的结点,则该二叉树中的总结点数为 ( A) 219 ( B) 221 ( C) 229 ( D) 231 9 下列叙述中正确的是 ( A)数据库系统是一个独立的系统,不需要操作系统的支持 ( B)数据库技术的根本目标是要解决数据的共享问题 ( C)数据库管理系统就是数据库系统 ( D)以上三种说法都不对 10 下列叙述中正确的是 ( A)为了建立一个关系,首先要构造数据的逻辑关系 ( B)表示关系的二维表中各元组的每一个分量还可以分成若干数据项 ( C)一个关系的属性名表称为关系模式 ( D)一个关系可以包括多个二维表 11 C语言源程序名的后缀是 ( A) .exe
4、( B) .C ( C) .obj ( D) .cp 12 可在 C程序中用作用户标识符的一组标识符是 ( A) and _2007 ( B) Date y-m-d ( C) Hi Df Tom ( D) case Big1 13 以下选项中,合法的 组 C语言数值常量是 ( A) 028 .5e-3 -Oxf ( B) 12 0Xa23 4.5e0 ( C) 177 4e1.5 0abc ( D) 0x8A 10,000 3.e5 14 以下叙述中正确的是 ( A) C语言程序将从源程序中第一个函数开始执行 ( B)可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行 ( C)
5、C语言规定必须用 main作为主函数名,程序将从此开始执行,在此结束 ( D) main可作为 用户标识符,用以命名任意一个函数作为主函数 15 若在定义语句: int a, b, c, *p= t-; return(t-s); 以下关于 aaa函数的功能的叙述正确的是 ( A)求字符串 s的长度 ( B)比较两个串的大小 ( C)将串 s复制到串 t ( D)求字符串 s所占字节数 31 若有定义语句: int a36;,按在内存中的存放顺序, a数组的第 10个元素是 ( A) a04 ( B) a13 ( C) a03 ( D) a14 32 有以下程序 #include stdio.h
6、 void fun(char *p) +p; printf(“%sn“,*p); main() char *a=“Moming“,“Afternoon“,“Evening“,“Night“; fun(a); 程序的运行结果是 ( A) Afternoon ( B) fternoon ( C) Morning ( D) orning 33 若有定义语句: int a23, *p3,则以下 语句中正确的是 ( A) p=a; ( B) p0=a; ( C) p0= for (i=0; i n-1 ;i+) for 0=i+l; j n; j+) if(ai aj) t=ai; ai=aj; aj=
7、t; main() int c10= 1,2,3,4,5,6,7,8,9,0,i; fun(c+4, 6); for (i=0;i 10; i+) printf(“%d,“, ci); printf(“n“); ( A) 1,2,3,4,5,6,7,8,9,0, ( B) 0,9,8,7,6,5,1,2,3,4, ( C) 0,9,8,7,6,5,4,3,2,1, ( D) 1,2,3,4,9,8,7,6,5,0, 35 有以下程序 #include stdio.h int fun(char s) int n=O; while(*s =9 s+; return (n); main() char
8、 s10= 6, 1, *, 4, *, 9, *, 0, *; printf(“%dn“,fun(s); ( A) 9 ( B) 61490 ( C) 61 ( D) 5 36 当用户要求输入的字符串中含有空格时,应使用的输入函数是 ( A) scanf() ( B) getchar() ( C) gets() ( D) getc() 37 以下关于字符串的叙述中正确的是 ( A) C语言中有字符串类型的常量和变量 ( B)两个字符串中的字符个数相同时才能进行字符串大小的比较 ( C)可以用关系运算符对字符串的大小进行比较 ( D)空串一定比空格打头的字符 串小 38 有以下程序 #incl
9、ude stdio.h void fun(char *t, char *s) while(*t!=0) t+; while( (*t+ = *s+ )!=0 ); main() char ss10=“acc“,aa10=“bbxxyy“; fun(ss, aa); printff“%s,%sn“, ss,aa); 程序的运行结果是 ( A) accxyy, bbxxyy ( B) acc, bbxxyy ( C) accxxyy, bbxxyy ( D) accbbxxyy, bbxxyy 39 有以下程序 #include stdio.h #include string.h void fun
10、(char s10,int n) char t; int i j; for (i=0; i n-1; i+) for 0-i+l; jn; j+) /*比较字符串的首字符大小,并交换字符串的首字符 */ if(si0 sj0) t = si0; si0 = sj0; sj0 = t; main() char ss510= “bcc“, “bbcc“, “xy“, “aaaacc“, “aabcc“ ; fun(ss, 5); printf(“%s,%sn“, ss0,ss4); 程序的运行结果是 ( A) xy, aaaacc ( B) aaaacc,xy ( C) xcc,aabcc ( D
11、) acc,xabcc 40 在一个 C源程序文件中所定义的全局变量,其作用域为 ( A)所在文件的全部范围 ( B)所在程序的全部范围 ( C)所在函数的全部范围 ( D)由具体定义位置和 extern说明来决定范围 41 有以下程序 #include stdio.h int a=1; int f(int c) static int a=2; c=c+1; return (a+) + c; main() int i, k=0; for(i=0;i 2;i+) int a=3; k += f(a); k +=a; printf(“%dn“,k); ( A) 14 ( B) 15 ( C) 16
12、 ( D) 17 42 有以下程序 #include stdio.h void fun(int n, int *p) int f1,t2; if(n=1 |n=2) *p=1; else fun(n-1, fun(n-2, *p=f1+f2; main() int s; fun(3, printf(“%dn“, s ); ( A) 2 ( B) 3 ( C) 4 ( D) 5 43 若程序中有宏定义行: #define N 100 则以下叙述中正确的是 ( A)宏定义行中定义了标识符 N的值为整数 100 ( B)在编译程序对 C 源程序进行预处理时用 100替换标识符 N ( C)对 C源程
13、序进行编译时用 100替换标识符 N ( D)在运行时用 100替换标识符 N 44 以下关于 typedef的叙述错误的是 ( A)用 typedef可以增加新类型 ( B) typedef只是将已存在的类型用一个新的名字来代表 ( C)用 typedef可以为各种类型说明一个新名,但不能用来为变量说明一个新名 ( D)用 typedef为类型说明一个新名, 通常可以增加程序的可读性 45 有以下程序 #include stdio.h struct tt int x; struct tt *y; *p; struct tt a4= 20,a+ 1,15,a+2,30,a+3,17,a; ma
14、in() int i; p=a; for(i=1; i -2; i+) printf(“%d,“, p- x ); p=p- y; ( A) 20,30, ( B) 30,17 ( C) 15,30, ( D) 20,15, 46 有以下程序 #include stdio.h #include string.h typedef struct char name9; char sex; float score2; STU; STU f(STU a) STU b=“Zhao“, m, 85.0, 90.0; int i; strcpy(a.name, b.name); a.sex = b.sex;
15、 for (i=0; i 2; i+) a.scorei = b.scorei; return a; main() STU c=“Qian“, T, 95.0, 92.0, d; d=f(c); printf(“%s,%c,%2.0f,%2.0fn“, d.name, 程序的运行结果是 ( A) Qian, f,95,92 ( B) Qian,m,85,90 ( C) Zhao,m,85,90 ( D) Zhao,f,95,92 47 设有以下定义 union data int d1; float d2; demo; 则下面叙述中错误的是 ( A)变量 demo与成员 d2所占的内存字节数相同
16、 ( B)变量 demo中各成员的地址相同 ( C)变量 demo和各成员的地址相同 ( D)若给 demo d1赋 99后, demo d2中的值是 99.0 48 有以下程序 #include stdio.h main() int a=1, b=2, c=3, x; x=(ab) printf(“%dn“,x); 程序的运行结果是 ( A) 0 ( B) 1 ( C) 2 ( D) 3 49 读取二进制文件的函数调用形式为: fread(buffer, size, count, fp);,其中buffer代表的是 ( A)一个文件指针,指向待读取的文件 ( B)一个整型变量 ,代表待读取的
17、数据的字节数 ( C)一个内存块的首地址,代表读入数据存放的地址 ( D) 个内存块的字节数 50 有以下程序 #include stdio.h main() FILE *fp; int a10=1,2,3,0,0,i; fp = fopen(“d2.dat“, “wb“); fwrite(a, sizeof(int), 5, fp); fwrite(a, sizeof(int), 5, fp); fclose(fp); fp = fopenCd2.dat“, “rb“); fread(a, sizeof(int), 10, fp); fclose(fp); for (i=0; i 10; i
18、+) printf(“%d,“, ai); ( A) 1,2,3,0,0,0,0,0,0,0, ( B) 1,2,3,1,2,3,0,0,0,0, ( C) 123,0,0,0,0,123,0,0,0,0, ( D) 1,2,3,0,0,1,2,3,0,0, 51 软件需求规格说明书应具有完整性 、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的是【 】。 52 在两种基本测试方法中,【 】测试的原则之一是保证所测模块中每一个独立路径至少要执行一次。 53 线性表的存储结构主要分为顺序存储结构和链式存储结构。队列是一种特殊的线性表,循环队列是队列的【 】存储结构。 54 对下列二叉树进
19、行中序遍历的结果为【 】。 55 在 E-R图中,矩形表示【 】。 56 执行以下程序时输入 1234567 CR,则输出结果是【 】。 #include stdio h main() int a=1,b; scanf(“%2d%2d“, prinff(“%d %dhn“,a,b); 57 以下程序的输出结果是【 】。 # include stdio.h main() int n=12345, d; while(n!=O) d=n%10; printf(“%d“,d); n/=10; 58 以下程序的输出结果是【 】。 #include stdio.h main() int i; for(i=
20、a; i f; i+,i+) printf(“%c“,i - a + A); printf(“n“); 59 以下程序的输出结果是【 】。 #include stdio.h #include string.h char *fun(char *0 char *p-t; return (p+strlen(t)/2); main() char *str=“abcdefgh“; str=ftm(str); puts(str); 60 执行以下程序的输出结果是【 】。 #include stdio.h main() int i, n4=1; for(i= 1 ;i =3 ;i+) ni=ni-1*2+1
21、; printf(“%d“,ni); 61 以下程序的输出结果是【 】。 #include stdio.h #define M 5 #define N M+M main0 int k; k = NN*5; printf(“%dn“,k); 62 函数 min()的功能是:在带头结点的单链表中查找数据域中值最小的结点。请填空 #include stdio.h struct node int data; struct node *next; ; int min(struct node *first)/*指针 first为链表头指针 */ struct node *p; int m; p=first
22、- next; re=p- data; p=p- next; for( ;p!=NULL;p=【 】 ) if(p- data m ) re=p- data; return m; 63 以下程序的功能是:输出 a、 b、 c三个变量中的最小值。 #include stdio.h main( ) int a,b,c,t 1,t2; scanf(“%d%d%d“, t1=a b ?【 】 ; t2=c t1?【 】 ; printf(“%dn“, t2 ); 64 有以下程序段,且变量已正确定义和赋值 for(s=1.0, k=1; k =; k+) s=s+1.0/(k*(k+1); print
23、f(“s=%fnn“, s); 请填空,使下面程序段的功能与之完全相同 s=1.0; k=1; while(【 】 ) s=s+1.0/(k*(k+1);【 】 ; prinff(“s=%fnn“, s); 65 以下程序中函数 f的功能是在数组 x的 n个数 (假定 n个数互不相同 )中找出最大最小数,将其中最小的数与第一个数对换,把最大的数与最后一个数对换。请填空。 # include stdio.h void f(int x, int n) int p0, p1, i,j,t,m; i=j=xO; p0=p1=O; for(m=0;m n;m+) if( xm i ) i=xm; p0=
24、m; else if(xm j) j=xm; p1=m; t=xp0; xp0=xn-1; xn-1=t; t=xp1; xp1=【 】 ;【 】 =t; main() int a10, u; for(u=O;u 10;u+) scanf(“%d“, f(a, 10); for(u=O;u 10;u+) printf(“ %d“, au); printf(“n“); 66 以下程序统计从终端输入的字符中大写字母的个数, num0中统计字母 A的个数, num1中统计字母 B的个数,其他依次类推。用 #号结束输入,请填空。 #include stdio.h #include ctype.h ma
25、in() int num26=0,i; char c; while(【 】 )!=#) if(isupper(c) hum c-A +=【 】 ; for(i=0; i 26; i+) printf(“%c: %dn “,i+A, numi); 2007 年 9月国家二级( C语言)笔试真题试卷答案与解析 1 【正确答案】 D 【试题解析】 本 题考查软件的定义。软件是计算机系统中与硬件相互依存得另一部分,它包括程序、相关数据及其说明文档得总和。因此,本题得正确答案是选项 D。 2 【正确答案】 B 【试题解析】 本题考查软件工程调试。调试与测试是两个不同的过程,有着根本的区别:调试是一个随机
26、的、不可重复的过程,它用于隔离和确认问题发生的原因,然后修改软件来纠正问题;测试是一个有计划的,可以重复的过程,它的目的是为了发现软件中的问题。因此,软件调试的目的是为了改正软什中的错误。本题的正确答案是选项 B。 3 【正确答案】 C 【试 题解析】 通常认为,面向对象方法具有封装性、继承性、多态性几大特点。就是这几大特点,为软件开发提供了一种新的方法学。 封装性:所谓封装就是将相关的信息、操作与处理融合在一个内含的部件中 (对象中 )。简单地说,封装就是隐藏信息。这是面向对象方法的中心,也是面向对象程序设计的基础。 继承性:子类具有派生它的类的全部属性 (数据 ) 和方法,而根据某一类建立
27、的对象也都具有该类的全部,这就是继承性。继承性自动在类勺子类间共享功能与数据,当某个类作了某项修改,其子类会自动改变,子类会继承其父类所有特性与行为 模式。继承有利于提高软件开发效率,容易达到一致性。 多态性:多态性就是多种形式。不同的对象在接收到相同的消息时,采用不同的动作。例如,一个应用程序包括许多对象,这些对象也许具有同一类犁的工作,但是却以不同的做法来实现。不必为每个对象的过程取一过程名,造成复杂化,可以使过程名复用。同一类型的工作有相同的过程名,这种技术称为多态性。 经过上述分析可知,在面向对象方法中,实现信息隐蔽是依靠对象的封装。正确答案是选项 C。 4 【正确答案】 A 【试题解
28、析】 本题考查软件工程的程序设计风格。软件 在编码阶段,力求程序语句简单、直接,不能只为了追求效率而使语句复杂化。除非对效率有特殊的要求,程序编写要做到清晰第一、效率第二。 人们在软件生存期要经常阅读程序,特别是在软什测试和维护阶段,编写程序的人和参与测试、维护的人都要阅读程序,因此要求程序的可读性要好。 正确的注释能够帮助读者理解程序,可为后续阶段进行测试和维护提供明确的指导。所以注释不是可有可无的,而是必须的,它对于理解程序具有重要的作用。 I/0 信息是与用户的使用直接相关的,因此它的格式应当尽可能方便用户的使用。在以交互式进行输入 /输出时,要在屏幕上使用提示符明确提示输入的请求,指明
29、可使用选项的种类和取值范围。 经过上述分析可知,选项 A是不符合良好程序设计风格要求的。 5 【正确答案】 A 【试题解析】 本题考查程序效率。程序效率是指程序运行速度和程序占用的存储空间。影响程序效率的因素是多方面的,包括程序的设计、使用的算法、数据的存储结构等。在确定数据逻辑结构的基础上,选择一种合适的存储结构,可以使得数据操作所花费的时间少,占用的存储空间少,即提高程序的效率。因此,本题选项 A的说法是正确的。 6 【正确答案】 D 【试题解析】 本题考查数据结构的基本知识。 数据之间的相互关系称为逻辑结构。通常分为四类基本逻辑结构,即集合、线性结构、树型结构、图状结构或网状结构。存储结
30、构是逻辑结构在存储器中的映象,它包含数据元素的映象和关系的映象。存储结构在计算机中有两种,即顺序存储结构和链式存储结构。顺序存储结构是把数据元素存储在一块连续地址空间的内存中:链式存储结构是使用指针把相互直接关联的节点链接起来。因此,这两种存储结构都是线性的。可见,逻辑结构和存储结构不是一一对应的。因此,选项 A和选项 B的说法都是错误的。 无论数据的逻辑结构是线性的还是非线性的,只能选择顺序存储结构或链式存储结构来实现存储。程序设计语言中,数组是内存中一段连续的地址空间,可看作是顺序存储结构。可以用数组来实现树型逻辑结构的存储,比如二叉树。因此,选项 C的说法是错误的。 7 【正确答案】 C
31、 【试题解析】 冒泡排序的基本思想是:将相邻的两个元素进行比较,如果反序,则交换:对于一个待排序的序列,经一趟排序后,最大值的元素移动到最后的位置,其他值较大的元素也向最终位置移动,此过程称为一趟冒泡。对于有 n个数据的序列,共需 n-1趟排序, 第 i趟对从 1到 n-i个数据进行比较、交换。冒泡排序的最坏情况是待排序序列逆序,第 1趟比较 n-1次,第 2趟比较 n-2次,依此类推,最后一趟比较 1次,一共进行 n-1趟排序。因此,冒泡排序在最坏情况下的比较次数是 (n-1)+(n-2)+1 ,结果为 n(n-1)/2。本题的正确答案是选项 C。 8 【正确答案】 A 【试题解析】 本题考
32、查数据结构中二叉树的性质。二叉树满足如下一条性质,即:对任意一棵二叉树,若终端结点 (即叶子结点 )数为 n0,而其度数为 2的结点数为 n2,则 n0=n2+1。根据这条性质可知,若二叉树中有 70 个叶子结点,则其度为 2的结点数为 70-1,即 69个。二叉树的总结点数是度为 2、度为 1和叶子结点的总和,因此,题目中的二叉树总结点数为 69+80+70,即 219。因此,本题的正确答案是选项 A。 9 【正确答案】 B 【试题解析】 本题考查数据库系统的基本概念和知识。 数据库系统除了数据库管理软件之外,还心须有其他相关软件的支持。这些软件包括操作系统、编译系统、应用软件开发工具等。对
33、于大型的多用户数据库系统和网络数据库系统,还需要 多用户系统软件和网络系统软件的支持。因此,选项A的说法是错误的。 数据库可以看成是长期存储在计算机内的、大量的、有结构的和可共享的数据集合。因此,数据库具有为各种用户所共享的特点。不同的用户可以使用同一个数据库,可以取出它们所需要的子集,而且容许子集任意重叠。数据库的根本目标是要解决数据的共享问题。因此,选项 B的说法是正确的。 通常将引入数据库技术的计算机系统称为数据库系统。一个数据库系统通常由五个部分组成,包括相关计算机的硬件、数据库集合、数据库管理系统、相关软件和人员。 因此,选项 C的 说法是错误的。 因此,本题的正确答案是选项 B。
34、10 【正确答案】 C 【试题解析】 本题考查数据库的关系模型。关系模型的数据结构是一个 “二维表 ”,每个二维表可称为一个关系,每个关系有一个关系名。表中的一行称为一个元组:表中的列称为属性,每一列有一个属性名。表中的每一个元组是属性值的集合,属性是关系二维表中最小的单位,它不能再被划分。关系模式是指一个关系的属性名表,即二维表的表框架。因此,选项 C的说法是正确的。 11 【正确答案】 B 【试题解析】 C浯言源程序的后缀为 .c;经过编 译得到的目标程序文件的后缀为 obj:再将目标程序文件链接后得到可执行文件的后缀为 .exe。故本题应该选择 B。 12 【正确答案】 A 【试题解析】
35、 用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列称为标识符。 C语言规定标识符只能由字母、数字和下划线三种字符组成,且第一个字符必须为字母或下划线。另外,标识符不能是 C语言关键字。选项 B中, y-m-d 用了 “-”所以不是标识符;选项 C, Dr.Tom用了 “.”也不是标识符;选项 D中, case是 C语言关键字,所以不能用作标识符。故本 题应该选择 A。 13 【正确答案】 B 【试题解析】 数值常量分为整型和实型两类。其中,整型有 卜进制、八进制和十六进制三种表示法;实型有小数形式和指数形式两种表示法。十进制和书面使用的数据表示一样;八进制是以数字 0开
36、头,后面跟由 0 7组成的八进制数组成:十六进制是以 0x(或 OX)开头,后面跟由 0 9与 A F(或 a f)组成的十六进制数组成:小数形式由数字和小数点组成,其整数部分或小数部分如果为 0可省略,但不能同时省略。指数形式由小数形式或十进制形式开头,后面跟 e(或 E),再跟一个十进制整数组成。 选项 A中, 028是八进制形式,但后面跟的 8不在0 7之内,所以非法;选项 C中, 4e1.5是指数形式,但 e后面所跟的不是整数,所以非法;选项 D中, 10,000中不能有 “, ”,所以非法。故本题应该选择 B。 14 【正确答案】 C 【试题解析】 C语言程序将从主函数 main()
37、开始执行,故选项 A不正确;主函数必须是 main(),故选项 B 不正确;主函数的返回类型必须为 int或 void,形参可以没有也可以为 int,char *。所以不是任意函数都能作为主函数,故选项 D不正确。本题应该选择 C。 15 【正确答案】 C 【试题解析】 scanf()函数要求,除了第 1个参数为格式化字符串以外,其余参数均为相应变量的地址值。本题中,只有 p是地址值,故应该选择 C。 16 【正确答案】 D 【试题解析】 在 C语言的标准中, short占 2个字节、 long占 4个字节,但 int的大小和编译系统相关。例如在 Turbo C 2.0中, int占 2个字节
38、,但在VisualC+6.0(VC6 可以用做 C语言编译器 )中占 4个字节。故本题应该选择 D。 17 【正确答案】 A 【试题解析】 赋值语句由两个运 算分量和一个赋值运算符组成。赋值运算符包括“二 ”、 “+=”、 “*=” 等。其中,赋值运算符左侧的运算分量称为左值,右侧的叫右值。任何合法表达式都可用做右值,但临时值、常量不能用做左值。 “%”运算符的作用是求模,意思是做除法求余,这就要求两个运算分量均为整数。选项B 中, 2.5不是整数,故非法:选项 C中,表达式 x+n计算后得到的是一临时值,临时值不能做左值,故非法;选项 D中,由于 “=”运算符的结合性是 “从右到左 ”,故先
39、计算 5=4+1, 5是常量不能做左值,故选项 D也非法。选项 A, y=5是一个逻辑表达式,其值为真 或假,可以用做右值,所以是合法的。故本题应该选择 A。 18 【正确答案】 B 【试题解析】 本题 scanf()函数的格式化控制串中, “%2d“表示输入一个 2位的整数: “%f“表示输入一个浮点数; “%s“表示输入一个字符串。因此,从键盘上输入 “55566 7777abc“后,前两位 “55“被当作 2位整数输入给 j; “566“被当作浮点数输入给 y;跳过空格后,剩下的字符串 “7777abc“全部输入给 name;故本题应该选择 B。 19 【正确答案】 B 【试题解析】 d
40、o while循环会 首先执行循环体 1遍,然后再判断 while后的逻辑表达式是否为真来决定是否进行下一次循环。所以, do while循环的循环体至少会被执行 1遍。本题中,首先令 i为 0,然后进入 do while循环,执行 1遍循环体输出 i的值 0。然后,因为表达式 i+的值为 0(执行后 i的值被增 1),所以 do while循环结束,接下来再输出 i的值 1。故本题应该选择B。 20 【正确答案】 B 【试题解析】 sqrt()函数的作用是计算 ,要求输出的参数 x必须大于等于 0。选项 B 一开始就调用了 sqrt(x)而没有判断 x的正负,所以是错误的。故应该选 B。 2
41、1 【正确答案】 B 【试题解析】 在 C语言中,逻辑表达式的结果只有两种情况 “tree”和 “false”。如果要把一个逻辑值看成一个整数的话, true等于 1; false等于 0。如果要把一个整数看成一个逻辑值的话,非 0等于 true: 0等于 false。由此可见,如果 EXP表达式的结果为 0的话; (EXP)为假: (EXP=0)为真; (EXP!=O)为假; (EXP=1)为假; (EXP!=1)为真。如果 EXP表达式的结果为非 0的话: (EXP)为真: (EXP 0)为假; (EXP!=0)为真; (EXP 1)结果不定; (EXP!=1)结果不定。综上所述,只有(E
42、XP!=0)完全等价于表达式 (EXP)。故应该选择 B。 22 【正确答案】 C 【试题解析】 本题首先令 y为 9,然后通过一个 for循环,当 y还大于 0则循环,每次循环让 y递减 1。循环体中是一条 if 语句,通过 %运算符计算每当 y能被3整除的时候,输出 -y的值,即先将 y减 1,然后输出 y的值。故当 y等于 9、6、 3时会输出,输出值分别为 8、 5、 2。所以应该选择 C。 23 【正确答案】 B 【试题解析】 大写字 母从 A Z的 ASCII码是连续的,所以如果当一个字符大于等于 A31小于等于 Z时,那这个字符就一定是一个大写字母,故选项 C正确。 C语言中的库
43、函数 isupper()的作用也正是判断一个字符是否为大写字母的,故选项 A正确。在 ASCII码中,小写字母的编码也是连续的,对应的小写字符比大写字符的 ASCII 码值大 32,所以选项 D经过小写字符 -32后,换算成了对应的大写字母 z和 A,所得到结果和选项 C是一致的,故也是正确的。选项 B中, C语言的逻辑表达式不能直接连写,而应该写成选项 C那样,故是错误的 ,应该选择 B。 24 【正确答案】 B 25 【正确答案】 D 【试题解析】 在定义函数时函数名后面括弧中的变量名称为 “形式参数 ”(简称形参 ),在主调函数中调用一个函数时,函数名后面括弧中的参数 (可以是一个表达式
44、 )称为 “实际参数 ” (简称实参 )。 C语言规定,实参变量对形参变量的数据传递是“值传递 ”,即单向传递,只由实参传给形参,而不能由形参传回来给实参。在内存中,实参单元与形参单元是不同的单元。故本题应该选择 D。 26 【正确答案】 C 【试题解析】 字符变量其实就是整型变量。只不过 它只占 1个字节,所以表示范围是 -128 127。它所储存的值为它所代表字符的 ASCII码值。 “己知字符, A,的ASCII代码值是 65,字符变量 c1 的值是 A”这句话告诉我们, c1 中存储的值就是65; c2 的值为 D,但在输出时减了 2,所以输出的值为 B,也就是 66。故本题应该选择
45、C。 27 【正确答案】 C 【试题解析】 在 C语言中,指针变量是不能直接赋给一个整数作为地址值的。因此选项 C是错误的。其余选项的说法正确。故应该选择 C。 28 【正确答案】 D 【试题解析】 在 C语言中,字 符串常量是以双引号括起来的字符序列。故选项 B和 C不正确。字符序列中可包含一些转义字符,转义字符都是以 “”开头的。选项A中包含了三个 “”,前两个 ()代表了 个 ”字符,后面一个和 “”一起 (“)被看作一个 “”,所以该字符串缺少一个结束的 “”,故不正确。选项 D的两个 “”之间没有任何字符,代表的是一个空串,是合法的字符串常量,故应该选择 D。 29 【正确答案】 A
46、 【试题解析】 sizeof()运算符的作用是计算一个变量所占的内存字节数。选项 A传入的是数组名 p,数组 p 由 3个字符大小,所 以占 3个字节。故不能计算出一个char型数据所占字符数。而选项 B、 C、 D传入的都是字符元素或字符类型名char,这些都能计算出一个 char型数据所占字符数。故本题应该选择 A。 30 【正确答案】 A 【试题解析】 aaa()函数中,首先定义了一个字符指针 t指向形参 s,然后通过一个 while循环让指针 t不断递增,直到 t指向字符串结束标志处。当 t指向结束标志处时,由于后缀 +运算符的原因,它还会被再递增 1,所以接卜来的 t-;语句让它回到结束标志处。最后返回 t-s,因此 s还是指向字符串第 1个字符处 ,而 t指向了字符串结尾,故返回值为字符串的长度值。 31 【正确答案】 B 【试题解析】 二维数组的元素在内存中是按行列顺序连续存放的。以本题的二维数组 a36为例,它的元素在内存中的存放顺序是: a00、 a01、a02a05 、 a10、 a11a15 、 a20a25 。由此可见,第 10个元素就是第 2行第 4个元素,即 a13