1、全国计算机等级考试二级 C 语言真题 2007 年 9 月及答案解析(总分:92.00,做题时间:90 分钟)一、B选择题/B(总题数:50,分数:60.00)1.软件是指(分数:2.00)A.程序B.程序和文档C.算法加数据结构D.程序、数据与相关文档的完整集合2.软件调试的目的是(分数:2.00)A.发现错误B.改正错误C.改善软件的性能D.验证软件的正确性3.在面向对象方法中,实现信息隐蔽是依靠(分数:2.00)A.对象的继承B.对象的多态C.对象的封装D.对象的分类4.下列叙述中,不符合良好程序设计风格要求的是(分数:2.00)A.程序的效率第一,清晰第二B.程序的可读性好C.程序中要
2、有必要的注释。D.输入数据前要有提示信息5.下列叙述中正确的是(分数:2.00)A.程序执行的效率与数据的存储结构密切相关B.程序执行的效率只取决于程序的控制结构C.程序执行的效率只取决于所处理的数据量D.以上三种说法都不对6.下列叙述中正确的是(分数:2.00)A.数据的逻辑结构与存储结构必定是一一对应的B.由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构C.程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线性结构D.以上三种说法都不对7.冒泡排序在最坏情况下的比较次数是(分数:2.00)A.n(n+1)/2B.nlog2nC.n(n-1)/2D.n/2
3、8.一棵二叉树中共有 70 个叶子结点与 80 个度为 1 的结点,则该二叉树中的总结点数为(分数:2.00)A.219B.221C.229D.2319.下列叙述中正确的是(分数:2.00)A.数据库系统是一个独立的系统,不需要操作系统的支持B.数据库技术的根本目标是要解决数据的共享问题C.数据库管理系统就是数据库系统D.以上三种说法都不对10.下列叙述中正确的是(分数:2.00)A.为了建立一个关系,首先要构造数据的逻辑关系B.表示关系的二维表中各元组的每一个分量还可以分成若干数据项C.一个关系的属性名表称为关系模式D.一个关系可以包括多个二维表11.C 语言源程序名的后缀是(分数:1.00
4、)AexeBCCobjDcp12.可在 C 程序中用作用户标识符的一组标识符是(分数:1.00)A.and _2007B.Date y-m-dC.Hi DTomD.case Big113.以下选项中,合法的组 C 语言数值常量是(分数:1.00)A.028 .5e-3 -OxfB.12 0Xa23 4.5e0C.177 4e1.5 0abcD.0x8A 10,000 3.e514.以下叙述中正确的是(分数:1.00)A.C 语言程序将从源程序中第一个函数开始执行B.可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C.C 语言规定必须用 main 作为主函数名,程序将从此开始执行
5、,在此结束D.main 可作为用户标识符,用以命名任意一个函数作为主函数15.若在定义语句:int a,b,c,*p= t-; return(t-s); 以下关于 aaa 函数的功能的叙述正确的是(分数:1.00)A.求字符串 s 的长度B.比较两个串的大小C.将串 s 复制到串 tD.求字符串 s 所占字节数31.若有定义语句:int a36;,按在内存中的存放顺序,a 数组的第 10 个元素是(分数:1.00)A.a04B.a13C.a03D.a1432.有以下程序 #include stdio.h void fun(char *p) +p; printf(“%s/n“,*p); main
6、() char *a=“Moming“,“Afternoon“,“Evening“,“Night“; fun(a); 程序的运行结果是(分数:1.00)A.AfternoonB.fternoonC.MorningD.orning33.若有定义语句:int a23,*p3,则以下语句中正确的是(分数:1.00)A.p=a;B.p0=a;C.p0= for (i=0; in-1 ;i+) for 0=i+l; jn; j+) if(aiaj) t=ai; ai=aj; aj=t; main() int c10= 1,2,3,4,5,6,7,8,9,0,i; fun(c+4, 6); for (i=
7、0;i10; i+) printf(“%d,“, ci); printf(“/n“); (分数:1.00)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 s10= 6, 1, *, 4, *, 9, *, 0, *; printf(“%d/n“,fun(s); (分数:1.00)A.9B.6
8、1490C.61D.536.当用户要求输入的字符串中含有空格时,应使用的输入函数是(分数:1.00)A.scanf()B.getchar()C.gets()D.getc()37.以下关于字符串的叙述中正确的是(分数:1.00)A.C 语言中有字符串类型的常量和变量B.两个字符串中的字符个数相同时才能进行字符串大小的比较C.可以用关系运算符对字符串的大小进行比较D.空串一定比空格打头的字符串小38.有以下程序 #include stdio.h void fun(char *t, char *s) while(*t!=0) t+; while( (*t+ = *s+ )!=0 ); main()
9、char ss10=“acc“,aa10=“bbxxyy“; fun(ss, aa); printff“%s,%s/n“, ss,aa); 程序的运行结果是(分数:1.00)A.accxyy, bbxxyyB.acc, bbxxyyC.accxxyy, bbxxyyD.accbbxxyy, bbxxyy39.有以下程序 #include stdio.h #include string.h void fun(char s10,int n) char t; int i j; for (i=0; in-1; i+) for 0-i+l; jn; j+) /*比较字符串的首字符大小,并交换字符串的首字
10、符*/ if(si0 sj0) t = si0; si0 = sj0; sj0 = t; main() char ss510= “bcc“, “bbcc“, “xy“, “aaaacc“, “aabcc“ ; fun(ss, 5); printf(“%s,%s/n“, ss0,ss4); 程序的运行结果是(分数:1.00)A.xy, aaaaccB.aaaacc,xyC.xcc,aabccD.acc,xabcc40.在一个 C 源程序文件中所定义的全局变量,其作用域为(分数:1.00)A.所在文件的全部范围B.所在程序的全部范围C.所在函数的全部范围D.由具体定义位置和 extern 说明来决
11、定范围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;i2;i+) int a=3; k += f(a); k +=a; printf(“%d/n“,k); (分数:1.00)A.14B.15C.16D.1742.有以下程序 #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
12、=f1+f2; main() int s; fun(3, printf(“%d/n“, s ); (分数:1.00)A.2B.3C.4D.543.若程序中有宏定义行:#define N 100 则以下叙述中正确的是(分数:1.00)A.宏定义行中定义了标识符 N 的值为整数 100B.在编译程序对 C 源程序进行预处理时用 100 替换标识符 NC.对 C 源程序进行编译时用 100 替换标识符 ND.在运行时用 100 替换标识符 N44.以下关于 typedef 的叙述错误的是(分数:1.00)A.用 typedef 可以增加新类型B.typedef 只是将已存在的类型用一个新的名字来代表
13、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; main() int i; p=a; for(i=1; i-2; i+) printf(“%d,“, p-x ); p=p-y; (分数:1.00)A.20,30,B.30,17C.15,30,D.20,15,46.有以下程序 #include
14、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; for (i=0; i2; 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.0f/n“, d.na
15、me, 程序的运行结果是(分数:1.00)A.Qian, f,95,92B.Qian,m,85,90C.Zhao,m,85,90D.Zhao,f,95,9247.设有以下定义 union data int d1; float d2; demo; 则下面叙述中错误的是(分数:1.00)A.变量 demo 与成员 d2 所占的内存字节数相同B.变量 demo 中各成员的地址相同C.变量 demo 和各成员的地址相同D.若给 demd1 赋 99 后,demd2 中的值是 99.048.有以下程序 #include stdio.h main() int a=1, b=2, c=3, x; x=(ab
16、) printf(“%d/n“,x); 程序的运行结果是(分数:1.00)A.0B.1C.2D.349.读取二进制文件的函数调用形式为:fread(buffer,size,count,fp);,其中 buffer 代表的是(分数:1.00)A.一个文件指针,指向待读取的文件B.一个整型变量,代表待读取的数据的字节数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(
17、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; i10; i+) printf(“%d,“, ai); (分数:1.00)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,二、B填空题/B(总题数:16,分数:32.00)51.软件需求规格
18、说明书应具有完整性、无歧义性、正确性、可验证性、可修改性等特性,其中最重要的是U 【1】 /U。(分数:2.00)填空项 1:_52.在两种基本测试方法中,U 【2】 /U测试的原则之一是保证所测模块中每一个独立路径至少要执行一次。(分数:2.00)填空项 1:_53.线性表的存储结构主要分为顺序存储结构和链式存储结构。队列是一种特殊的线性表,循环队列是队列的U 【3】 /U存储结构。(分数:2.00)填空项 1:_54.对下列二叉树进行中序遍历的结果为U 【4】 /U。 (分数:2.00)填空项 1:_55.在 E-R 图中,矩形表示U 【5】 /U。(分数:2.00)填空项 1:_56.执
19、行以下程序时输入 1234567CR,则输出结果是U 【6】 /U。 #include stdioh main() int a=1,b; scanf(“%2d%2d“, prinff(“%d %dhn“,a,b); (分数:2.00)填空项 1:_57.以下程序的功能是:输出 a、b、c 三个变量中的最小值。 #include stdio.h main( ) int a,b,c,t 1,t2; scanf(“%d%d%d“, t1=ab ?U 【7】 /U; t2=ct1?U 【8】 /U; printf(“%d/n“, t2 ); (分数:2.00)填空项 1:_58.以下程序的输出结果是U
20、 【9】 /U。 # include stdio.h main() int n=12345, d; while(n!=O) d=n%10; printf(“%d“,d); n/=10; (分数:2.00)填空项 1:_59.有以下程序段,且变量已正确定义和赋值 for(s=1.0, k=1; k=; k+) s=s+1.0/(k*(k+1); printf(“s=%f/n/n“, s); 请填空,使下面程序段的功能与之完全相同 s=1.0; k=1; while(U 【10】 /U) s=s+1.0/(k*(k+1);U 【11】 /U; prinff(“s=%f/nn“, s);(分数:2.
21、00)填空项 1:_60.以下程序的输出结果是U 【12】 /U。 #include stdio.h main() int i; for(i=a; if; i+,i+) printf(“%c“,i - a + A); printf(“/n“); (分数:2.00)填空项 1:_61.以下程序的输出结果是U 【13】 /U。 #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(s
22、tr); (分数:2.00)填空项 1:_62.以下程序中函数 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;mn;m+) if( xmi ) i=xm; p0=m; else if(xmj) j=xm; p1=m; t=xp0; xp0=xn-1; xn-1=t; t=xp1; xp1=U 【14】 /U;U 【15】 /U=
23、t; main() int a10, u; for(u=O;u10;u+) scanf(“%d“, f(a, 10); for(u=O;u10;u+) printf(“ %d“, au); printf(“/n“); (分数:2.00)填空项 1:_63.以下程序统计从终端输入的字符中大写字母的个数,num0中统计字母 A 的个数, num1中统计字母B 的个数,其他依次类推。用#号结束输入,请填空。 #include stdio.h #include ctype.h main() int num26=0,i; char c; while(U 【16】 /U)!=#) if(isupper(c
24、) hum c-A +=U 【17】 /U; for(i=0; i26; i+) printf(“%c: %d/n “,i+A, numi);(分数:2.00)填空项 1:_64.执行以下程序的输出结果是U 【18】 /U。 #include stdio.h main() int i, n4=1; for(i= 1 ;i=3 ;i+) ni=ni-1*2+1; printf(“%d“,ni); (分数:2.00)填空项 1:_65.以下程序的输出结果是U 【19】 /U。 #include stdio.h #define M 5 #define N M+M main0 int k; k = N
25、N*5; printf(“%d/n“,k); (分数:2.00)填空项 1:_66.函数 min()的功能是:在带头结点的单链表中查找数据域中值最小的结点。请填空 #include stdio.h struct node int data; struct node *next; ; int min(struct node *first)/*指针first 为链表头指针*/ struct node *p; int m; p=first-next; re=p-data; p=p-next; for( ;p!=NULL;p=U 【20】 /U) if(p-datam ) re=p-data; ret
26、urn m; (分数:2.00)填空项 1:_全国计算机等级考试二级 C 语言真题 2007 年 9 月答案解析(总分:92.00,做题时间:90 分钟)一、B选择题/B(总题数:50,分数:60.00)1.软件是指(分数:2.00)A.程序B.程序和文档C.算法加数据结构D.程序、数据与相关文档的完整集合 解析:解析 本题考查软件的定义。软件是计算机系统中与硬件相互依存得另一部分,它包括程序、相关数据及其说明文档得总和。因此,本题得正确答案是选项 D。2.软件调试的目的是(分数:2.00)A.发现错误B.改正错误 C.改善软件的性能D.验证软件的正确性解析:解析 本题考查软件工程调试。调试与
27、测试是两个不同的过程,有着根本的区别:调试是一个随机的、不可重复的过程,它用于隔离和确认问题发生的原因,然后修改软件来纠正问题;测试是一个有计划的,可以重复的过程,它的目的是为了发现软件中的问题。因此,软件调试的目的是为了改正软什中的错误。本题的正确答案是选项 B。3.在面向对象方法中,实现信息隐蔽是依靠(分数:2.00)A.对象的继承B.对象的多态C.对象的封装 D.对象的分类解析:解析 通常认为,面向对象方法具有封装性、继承性、多态性几大特点。就是这几大特点,为软件开发提供了一种新的方法学。 封装性:所谓封装就是将相关的信息、操作与处理融合在一个内含的部件中 (对象中)。简单地说,封装就是
28、隐藏信息。这是面向对象方法的中心,也是面向对象程序设计的基础。 继承性:子类具有派生它的类的全部属性 (数据) 和方法,而根据某一类建立的对象也都具有该类的全部,这就是继承性。继承性自动在类勺子类间共享功能与数据,当某个类作了某项修改,其子类会自动改变,子类会继承其父类所有特性与行为模式。继承有利于提高软件开发效率,容易达到一致性。 多态性:多态性就是多种形式。不同的对象在接收到相同的消息时,采用不同的动作。例如,一个应用程序包括许多对象,这些对象也许具有同一类犁的工作,但是却以不同的做法来实现。不必为每个对象的过程取一过程名,造成复杂化,可以使过程名复用。同一类型的工作有相同的过程名,这种技
29、术称为多态性。 经过上述分析可知,在面向对象方法中,实现信息隐蔽是依靠对象的封装。正确答案是选项 C。4.下列叙述中,不符合良好程序设计风格要求的是(分数:2.00)A.程序的效率第一,清晰第二 B.程序的可读性好C.程序中要有必要的注释。D.输入数据前要有提示信息解析:解析 本题考查软件工程的程序设计风格。软件在编码阶段,力求程序语句简单、直接,不能只为了追求效率而使语句复杂化。除非对效率有特殊的要求,程序编写要做到清晰第一、效率第二。 人们在软件生存期要经常阅读程序,特别是在软什测试和维护阶段,编写程序的人和参与测试、维护的人都要阅读程序,因此要求程序的可读性要好。 正确的注释能够帮助读者
30、理解程序,可为后续阶段进行测试和维护提供明确的指导。所以注释不是可有可无的,而是必须的,它对于理解程序具有重要的作用。 I/0信息是与用户的使用直接相关的,因此它的格式应当尽可能方便用户的使用。在以交互式进行输入/输出时,要在屏幕上使用提示符明确提示输入的请求,指明可使用选项的种类和取值范围。 经过上述分析可知,选项 A 是不符合良好程序设计风格要求的。5.下列叙述中正确的是(分数:2.00)A.程序执行的效率与数据的存储结构密切相关 B.程序执行的效率只取决于程序的控制结构C.程序执行的效率只取决于所处理的数据量D.以上三种说法都不对解析:解析 本题考查程序效率。程序效率是指程序运行速度和程
31、序占用的存储空间。影响程序效率的因素是多方面的,包括程序的设计、使用的算法、数据的存储结构等。在确定数据逻辑结构的基础上,选择一种合适的存储结构,可以使得数据操作所花费的时间少,占用的存储空间少,即提高程序的效率。因此,本题选项 A 的说法是正确的。6.下列叙述中正确的是(分数:2.00)A.数据的逻辑结构与存储结构必定是一一对应的B.由于计算机存储空间是向量式的存储结构,因此,数据的存储结构一定是线性结构C.程序设计语言中的数组一般是顺序存储结构,因此,利用数组只能处理线性结构D.以上三种说法都不对 解析:解析 本题考查数据结构的基本知识。 数据之间的相互关系称为逻辑结构。通常分为四类基本逻
32、辑结构,即集合、线性结构、树型结构、图状结构或网状结构。存储结构是逻辑结构在存储器中的映象,它包含数据元素的映象和关系的映象。存储结构在计算机中有两种,即顺序存储结构和链式存储结构。顺序存储结构是把数据元素存储在一块连续地址空间的内存中:链式存储结构是使用指针把相互直接关联的节点链接起来。因此,这两种存储结构都是线性的。可见,逻辑结构和存储结构不是一一对应的。因此,选项 A 和选项 B 的说法都是错误的。 无论数据的逻辑结构是线性的还是非线性的,只能选择顺序存储结构或链式存储结构来实现存储。程序设计语言中,数组是内存中一段连续的地址空间,可看作是顺序存储结构。可以用数组来实现树型逻辑结构的存储
33、,比如二叉树。因此,选项 C 的说法是错误的。7.冒泡排序在最坏情况下的比较次数是(分数:2.00)A.n(n+1)/2B.nlog2nC.n(n-1)/2 D.n/2解析:解析 冒泡排序的基本思想是:将相邻的两个元素进行比较,如果反序,则交换:对于一个待排序的序列,经一趟排序后,最大值的元素移动到最后的位置,其他值较大的元素也向最终位置移动,此过程称为一趟冒泡。对于有 n 个数据的序列,共需 n-1 趟排序,第 i 趟对从 1 到 n-i 个数据进行比较、交换。冒泡排序的最坏情况是待排序序列逆序,第 1 趟比较 n-1 次,第 2 趟比较 n-2 次,依此类推,最后一趟比较 1 次,一共进行
34、 n-1 趟排序。因此,冒泡排序在最坏情况下的比较次数是(n-1)+(n-2)+1,结果为 n(n-1)/2。本题的正确答案是选项 C。8.一棵二叉树中共有 70 个叶子结点与 80 个度为 1 的结点,则该二叉树中的总结点数为(分数:2.00)A.219 B.221C.229D.231解析:解析 本题考查数据结构中二叉树的性质。二叉树满足如下一条性质,即:对任意一棵二叉树,若终端结点(即叶子结点)数为 n0,而其度数为 2 的结点数为 n 2,则 n0=n2+1。根据这条性质可知,若二叉树中有 70 个叶子结点,则其度为 2 的结点数为 70-1,即 69 个。二叉树的总结点数是度为 2、度
35、为 1 和叶子结点的总和,因此,题目中的二叉树总结点数为 69+80+70,即 219。因此,本题的正确答案是选项 A。9.下列叙述中正确的是(分数:2.00)A.数据库系统是一个独立的系统,不需要操作系统的支持B.数据库技术的根本目标是要解决数据的共享问题 C.数据库管理系统就是数据库系统D.以上三种说法都不对解析:解析 本题考查数据库系统的基本概念和知识。 数据库系统除了数据库管理软件之外,还心须有其他相关软件的支持。这些软件包括操作系统、编译系统、应用软件开发工具等。对于大型的多用户数据库系统和网络数据库系统,还需要多用户系统软件和网络系统软件的支持。因此,选项 A 的说法是错误的。数据
36、库可以看成是长期存储在计算机内的、大量的、有结构的和可共享的数据集合。因此,数据库具有为各种用户所共享的特点。不同的用户可以使用同一个数据库,可以取出它们所需要的子集,而且容许子集任意重叠。数据库的根本目标是要解决数据的共享问题。因此,选项 B 的说法是正确的。 通常将引入数据库技术的计算机系统称为数据库系统。一个数据库系统通常由五个部分组成,包括相关计算机的硬件、数据库集合、数据库管理系统、相关软件和人员。 因此,选项 C 的说法是错误的。 因此,本题的正确答案是选项 B。10.下列叙述中正确的是(分数:2.00)A.为了建立一个关系,首先要构造数据的逻辑关系B.表示关系的二维表中各元组的每
37、一个分量还可以分成若干数据项C.一个关系的属性名表称为关系模式 D.一个关系可以包括多个二维表解析:解析 题考查数据库的关系模犁。关系模型的数据结构是一个“二维表”,每个二维表可称为一个关系,每个关系有一个关系名。表中的一行称为一个元组:表中的列称为属性,每一列有一个属性名。表中的每一个元组是属性值的集合,属性是关系二维表中最小的单位,它不能再被划分。关系模式是指一个关系的属性名表,即二维表的表框架。因此,选项 C 的说法是正确的。11.C 语言源程序名的后缀是(分数:1.00)AexeBC CobjDcp解析:解析 本题考查的知识点是:C 语言的基本概念。 C 浯言源程序的后缀为.c;经过编
38、译得到的目标程序文件的后缀为obj:再将目标程序文件链接后得到可执行文件的后缀为.exe。故本题应该选择B。12.可在 C 程序中用作用户标识符的一组标识符是(分数:1.00)A.and _2007 B.Date y-m-dC.Hi DTomD.case Big1解析:解析 本题考查的知识点是:标识符。 用来标识变量名、符号常量名、函数名、数组名、类型名、文件名的有效字符序列称为标识符。C 语言规定标识符只能由字母、数字和下划线三种字符组成,且第一个字符必须为字母或下划线。另外,标识符不能是 C 语言关键字。选项 B 中,y-m-d 用了“-”所以不是标识符;选项 C,Dr.Tom 用了“.”
39、也不是标识符;选项 D 中,case 是 C 语言关键字,所以不能用作标识符。故本题应该选择 A。13.以下选项中,合法的组 C 语言数值常量是(分数:1.00)A.028 .5e-3 -OxfB.12 0Xa23 4.5e0 C.177 4e1.5 0abcD.0x8A 10,000 3.e5解析:解析 本题考查的知识点是:数值常量。 数值常量分为整型和实型两类。其中,整型有卜进制、八进制和十六进制三种表示法;实型有小数形式和指数形式两种表示法。十进制和书面使用的数据表示一样;八进制是以数字 0 开头,后面跟由 07 组成的八进制数组成:十六进制是以 0x(或 OX)开头,后面跟由 09 与
40、 AF(或 af)组成的十六进制数组成:小数形式由数字和小数点组成,其整数部分或小数部分如果为 0 可省略,但不能同时省略。指数形式由小数形式或十进制形式开头,后面跟 e(或 E),再跟一个十进制整数组成。选项 A 中, 028 是八进制形式,但后面跟的 8 不在 07 之内,所以非法;选项 C 中,4e1.5 是指数形式,但 e 后面所跟的不是整数,所以非法;选项 D 中,10,000 中不能有“,”,所以非法。故本题应该选择 B。14.以下叙述中正确的是(分数:1.00)A.C 语言程序将从源程序中第一个函数开始执行B.可以在程序中由用户指定任意一个函数作为主函数,程序将从此开始执行C.C
41、 语言规定必须用 main 作为主函数名,程序将从此开始执行,在此结束 D.main 可作为用户标识符,用以命名任意一个函数作为主函数解析:解析 本题考查的知识点是:C 语言的基本概念。 C 语言程序将从主函数 main()开始执行,故选项 A 不正确;主函数必须是 main(),故选项 B 不正确;主函数的返回类型必须为 int 或 void,形参可以没有也可以为 int,char *。所以不是任意函数都能作为主函数,故选项 D 不正确。本题应该选择 C。15.若在定义语句:int a,b,c,*p= t-; return(t-s); 以下关于 aaa 函数的功能的叙述正确的是(分数:1.0
42、0)A.求字符串 s 的长度 B.比较两个串的大小C.将串 s 复制到串 tD.求字符串 s 所占字节数解析:解析 本题考查的知识点是:while 循环的简单应用。 aaa()函数中,首先定义了一个字符指针t 指向形参 s,然后通过一个 while 循环让指针 t 不断递增,直到 t 指向字符串结束标志处。当 t 指向结束标志处时,由于后缀+运算符的原因,它还会被再递增 1,所以接卜来的 t-;语句让它回到结束标志处。最后返回 t-s,因此 s 还是指向字符串第 1 个字符处,而 t 指向了字符串结尾,故返回值为字符串的长度值。31.若有定义语句:int a36;,按在内存中的存放顺序,a 数
43、组的第 10 个元素是(分数:1.00)A.a04B.a13 C.a03D.a14解析:解析 本题考查的知识点是:二维数组在内存中的存放顺序。 二维数组的元素在内存中是按行列顺序连续存放的。以本题的二维数组 a36为例,它的元素在内存中的存放顺序是:a00、a01、a02a05、a10、 a11a15、a20a25。由此可见,第 10 个元素就是第2 行第 4 个元素,即 a13。故应该选择 B。32.有以下程序 #include stdio.h void fun(char *p) +p; printf(“%s/n“,*p); main() char *a=“Moming“,“Afternoo
44、n“,“Evening“,“Night“; fun(a); 程序的运行结果是(分数:1.00)A.Afternoon B.fternoonC.MorningD.orning解析:解析 本题考查的知识点是;指针数组和二级指针。 本题主函数中定义了一个指针数组 a,可以将它看成一个以字符指针为元素的一维数组。和般的一维数组名能赋给同类型指针变量一样,该字符指针数组也可以赋给指向字符指针的指针(即字符型二级指针),所以数组名 a 可以用作函数 fun()的实参。 在 fun()函数中,+p 操作使形参 p 往后移动一个字符指针的位置,即指针 a1的位置。故最后通过printf()函数输出的字符串为“
45、Afternoon“,应该选择 A。33.若有定义语句:int a23,*p3,则以下语句中正确的是(分数:1.00)A.p=a;B.p0=a;C.p0= for (i=0; in-1 ;i+) for 0=i+l; jn; j+) if(aiaj) t=ai; ai=aj; aj=t; main() int c10= 1,2,3,4,5,6,7,8,9,0,i; fun(c+4, 6); for (i=0;i10; i+) printf(“%d,“, ci); printf(“/n“); (分数:1.00)A.1,2,3,4,5,6,7,8,9,0,B.0,9,8,7,6,5,1,2,3,4
46、,C.0,9,8,7,6,5,4,3,2,1,D.1,2,3,4,9,8,7,6,5,0, 解析:解析 本题考查的知识点是:for 循环的简单应用。 题目中 fun()函数的作用是排序,从形参指针 a 所指位置开始,对其后 n 个 int 型元素进行从大到小排序。主函数中,调用 fun()函数传入的两个实参分别为 c+4 和 6,即从数组 c 的第 5 个元素开始,对其后连续的 6 个元素进行从大到小排序。所以,最后通过 for 循环输出数组 c 的值为“1,2,3,4,9,8,7,6,5,0,”,故应该选择 D。35.有以下程序 #include stdio.h int fun(char s) int n=O; while(*s=9 s+; return (n); main()