机密★启用前 |
| 2011年9月全国计算机等级考试二级笔试试题 |
| C语言程序设计 |
| (考试时间90分钟,满分100分) |
|
一、选择题((1)-(10)、(21)-(40)每题2分,(11)-(20)每题1分,共70分)
下列各题A)、B)、C)、D)四个选项中,只有一个选项是正确的。请将正确选项填涂在答题卡相应位置上,答在试卷上不得分。
|
| (1)下列叙述中正确的是 |
| A)算法就是程序 |
| B)设计算法时只需要考虑数据结构的设计 |
| C)设计算法时只需要考虑结果的可靠性 |
| D)以上三种说法都不对 |
|
|
|
|
|
|
| (2)下列关于线性链表的叙述中,正确的是 |
| A)各数据结点的存储空间可以不连续,但它们的存储顺序与逻辑顺序必须一致 |
| B)各数据结点的存储顺序与逻辑顺序可以不一致,但它们的存储空间必须连续 |
| C)进行插入与删除时,不需要移动表中的元素 |
| D)以上三种说法都不对 |
|
|
|
|
|
|
| (3)下列关于二叉树的叙述中,正确的是 |
| A)叶子结点总是比度为2的结点少一个 |
| B)叶子结点总是比度为2的结点多一个 |
| C)叶子结点数是度为2的结点数的两倍 |
| D)度为2的结点数是度为1的结点数的两倍 |
|
|
|
|
|
|
| (4)软件按功能可以分为应用软件、系统软件和支撑软件(或工具软件)。下面属于应用软件的是 |
| A)学生成绩管理系统 | B)C语言编译程序 |
| C)UNIX操作系统 | D)数据库管理系统 |
|
|
|
|
|
|
|
| (5)某系统总体结构图如下图所示: |
 |
| 该系统总体结构图的深度是 |
|
|
|
|
|
|
|
|
| (6)程序调试的任务是 |
| A)设计测试用例 | B)验证程序的正确性 |
| C)发现程序中的错误 | D)诊断和改正程序中的错误 |
|
|
|
|
|
|
|
| (7)下列关于数据库设计的叙述中,正确的是 |
| A)在需求分析阶段建立数据字典 | B)在概念设计阶段建立数据字典 |
| C)在逻辑设计阶段建立数据字典 | D)在物理设计阶段建立数据字典 |
|
|
|
|
|
|
|
| (8)数据库系统的三级模式不包括 |
|
|
|
|
|
|
|
|
| (9)有三个关系R、S和T如下: |
 |
| 则由关系R和S得到关系T的操作是 |
|
|
|
|
|
|
|
|
| (10)下列选项中属于面向对象设计方法主要特征的是 |
|
|
|
|
|
|
|
|
| (11)以下叙述中错误的是 |
| A)C语言编写的函数源程序,其文件名后缀可以是.C |
| B)C语言编写的函数都可以作为一个独立的源程序文件 |
| C)C语言编写的每个函数都可以进行独立的编译并执行 |
| D)一个C语言程序只能有一个主函数 |
|
|
|
|
|
|
| (12)以下选项中关于程序模块化的叙述错误的是 |
| A)把程序分成若干相对独立的模块,可便于编码和调试 |
| B)把程序分成若干相对独立、功能单一的模块,可便于重复使用这些模块 |
| C)可采用自底向上、逐步细化的设计方法把若干独立模块组装成所要求的程序 |
| D)可采用自顶向下、逐步细化的设计方法把若干独立模块组装成所要求的程序 |
|
|
|
|
|
|
| (13)以下选项中关于C语言常量的叙述错误的是 |
| A)所谓常量,是指在程序运行过程中,其值不能被改变的量 |
| B)常量分为整型常量、实型常量、字符常量和字符串常量 |
| C)常量可分为数值型和非数值型常量 |
| D)经常被使用的变量可以定义成常量 |
|
|
|
|
|
|
| (14)若有定义语句:int a=10; double b=3.14;,则表达式'A'+a+b值的类型是 |
| A)char | B)int |
C)double | D)float |
|
|
|
|
|
|
|
| (15)若有定义语句:int x=12,y=8,z;,在其后执行语句z=0.9+x/y;,则z的值为 |
|
|
|
|
|
|
|
|
| (16)若有定义:int a,b;,通过语句scanf("%d;%d",&a,&b);,能把整数3赋给变量a,5赋给变量b的输入数据是 |
|
|
|
|
|
|
|
|
| (17)若有定义语句:int k1=10,k2=20;,执行表达式(k1=k1>k2)&&(k2=k2>k1)后,k1和k2的值分别为 |
| A)0和1 | B)0和20 |
C)10和1 | D)10和20 |
|
|
|
|
|
|
|
| (18)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (19)下列条件语句中,输出结果与其他语句不同的是 |
| A)if(a) printf("%d\n",x); else printf("%d\n",y); |
| B)if(a==0) printf("%d\n",y); else printf("%d\n",x); |
| C)if(a!=0) printf("%d\n",x); else printf("%d\n",y); |
| D)if(a==0) printf("%d\n",x); else printf("%d\n",y); |
|
|
|
|
|
|
| (20)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (21)以下不能输出字符A的语句是(注:字符A的ASCII码值为65,字符a的ASCII码值为97) |
| A)printf("%c\n", 'a'-32); | B)printf("%d\n",'A'); |
| C)printf("%c\n",65); | D)printf("%c\n",'B'-1); |
|
|
|
|
|
|
|
| (22)有以下程序(注:字符a的ASCII码值为97) |
 |
| 程序运行后的输出结果是 |
| A)abc | B)789 |
C)7890 | D)979800 |
|
|
|
|
|
|
|
| (23)若有定义语句: double a, *p=&a;以下叙述中错误的是 |
| A)定义语句中的*号是一个地址运算符 |
| B)定义语句中的*号只是一个说明符 |
| C)定义语句中的p只能存放double类型变量的地址 |
| D)定义语句中,*p=&a把变量a的地址作为初值赋给指针变量p |
|
|
|
|
|
|
| (24)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (25)若有定义语句:int year=2009,*p=&year;,以下不能使变量year中的值增至2010的语句是 |
| A)*p+=1; | B)(*p)++; |
C)++(*p); | D)*p++; |
|
|
|
|
|
|
|
| (26)以下定义数组的语句中错误的是 |
| A)int num[ ]={1,2,3,4,5,6}; | B)int num[ ][3]={{1,2},3,4,5,6}; |
| C)int num[2][4]={{1,2},{3,4},{5,6}}; | D)int num[ ][4]={1,2,3,4,5,6}; |
|
|
|
|
|
|
|
| (27)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (28)有以下程序 |
 |
| 程序运行后的输出结果是 |
| A)-12,-3,0,0 | B)-3,-1,1,3 |
C)0,1,2,3 | D)-3,-3,-3,-3 |
|
|
|
|
|
|
|
| (29)有以下函数 |
 |
| 函数的功能是 |
| A)查找x和y所指字符串中是否有'\0' |
| B)统计x和y 所指字符串中最前面连续相同的字符个数 |
| C)将y所指字符串赋给x所指存储空间 |
| D)统计x和y所指字符串中相同的字符个数 |
|
|
|
|
|
|
| (30)若有定义语句:char *s1="OK",*s2="ok";,以下选项中,能够输出“OK”的语句是 |
| A)if(strcmp(s1,s2)==0) puts(s1); | B)if(strcmp(s1,s2)!=0) puts(s2); |
| C)if(strcmp(s1,s2)==1) puts(s1); | D)if(strcmp(s1,s2)!=0) puts(s1); |
|
|
|
|
|
|
|
| (31)以下程序的主函数中调用了在其前面定义的fun函数 |
 |
| 则以下选项中错误的fun函数首部是 |
| A)double fun(double a[15]) | B)double fun(double *a) |
| C)double fun(double a[ ]) | D)double fun(double a) |
|
|
|
|
|
|
|
| (32)有以下程序 |
 |
| 程序运行后的输出结果是 |
| A)beijing | B)china |
C)welcome | D)tiananmen |
|
|
|
|
|
|
|
| (33)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (34)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (35)有以下程序 |
 |
| 程序运行后的输出结果是 |
| A)654321 | B)116611 |
C)161616 | D)123456 |
|
|
|
|
|
|
|
| (36)有以下程序 |
 |
| 程序运行后的输出结果是 |
| A)Zhao,m,85,90,Qian,f,95,92 | B)Zhao,m,85,90,Zhao,m,85,90 |
| C)Qian,f,95,92,Qian,f,95,92 | D)Qian,f,95,92,Zhao,m,85,90 |
|
|
|
|
|
|
|
| (37)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (38)有以下程序 |
 |
| 程序运行后的输出结果是 |
|
|
|
|
|
|
|
|
| (39)以下选项中叙述错误的是 |
| A)C程序函数中定义的赋有初值的静态变量,每调用一次函数,赋一次初值 |
| B)在C程序的同一函数中,各复合语句内可以定义变量,其作用域仅限本复合语句内 |
| C)C程序函数中定义的自动变量,系统不自动赋确定的初值 |
| D)C程序函数的形参不可以说明为static型变量 |
|
|
|
|
|
|
| (40)有以下程序 |
 |
| 程序运行后的输出结果是 |
| A)1,2 | B)3,4 |
C)5,6 | D)123,456 |
|
|
|
|
|
|
|
二、填空题(每个小题2分,共30分)
请将每空的正确答案写在答题卡【1】~【15】序号的横线上,答在试卷上不得分。
|
| (1)数据结构分为线性结构与非线性结构,带链的栈属于 【1】 。 |
|
|
|
|
|
|
| (2)在长度为n的顺序存储的线性表中插入一个元素,最坏情况下需要移动表中 【2】 个元素。 |
|
|
|
|
|
|
| (3)常见的软件开发方法有结构化方法和面向对象方法。对某应用系统经过需求分析建立数据流图(DFD),则应采用 【3】 方法。 |
|
|
|
|
|
|
| (4)数据库系统的核心是 【4】 。 |
|
|
|
|
|
|
| (5)在进行关系数据库的逻辑设计时,E-R图中的属性常被转换为关系中的属性,联系通常被转换为 【5】 。 |
|
|
|
|
|
|
| (6)若程序中已给整型变量a和b赋值10和20,请写出按以下格式输出a、b值的语句 【6】 。 |
| ****a=10,b=20**** |
|
|
|
|
|
|
| (7)以下程序运行后的输出结果是 【7】 。 |
 |
|
|
|
|
|
|
| (8)以下程序运行后的输出结果是 【8】 。 |
 |
|
|
|
|
|
|
| (9)以下程序运行后的输出结果是 【9】 。 |
 |
|
|
|
|
|
|
| (10)以下程序运行后的输出结果是 【10】 。 |
 |
|
|
|
|
|
|
| (11)以下程序运行后的输出结果是 【11】 。 |
 |
|
|
|
|
|
|
| (12)有以下程序 |
 |
| 若程序运行时从键盘输入ABCACC<回车>,则输出结果为 【12】 。 |
|
|
|
|
|
|
| (13)以下程序运行后的输出结果是 【13】 。 |
 |
|
|
|
|
|
|
| (14)以下程序调用fun函数把x中的值插入到a数组下标为k的数组元素中。主函数中,n存放a数组中数据的个数,请填空。 |
 |
|
|
|
|
|
|
|
|
|
|
|
|
|