1、二级 C+笔试 88及答案解析(总分:96.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.软件开发离不开系统环境资源的支持,其中必要的测试数据属于(分数:2.00)A.硬件资源B.通信资源C.支持软件D.辅助资源2.以下叙述正确的是(分数:2.00)A.函数可以嵌套定义但不能嵌套调用B.函数既可以嵌套调用也可以嵌套定义C.函数既不可以嵌套定义也不可以嵌套调用D.函数可以嵌套调用但不可以嵌套定义3.下面有关 for循环的正确描述是(分数:2.00)A.for循环只能用于循环次数已经确定的情况B.for循环是先执行循环体语句,后判断表达式C.在 for循环中,不
2、能用 break语句跳出循环体D.for循环的循环体语句中,可以包含多条语句,但必须用花括号括起来5.在单链表中,增加头结点的目的是(分数:2.00)A.方便运算的实现B.使单链表至少有一个结点C.标识表结点中首结点的位置D.说明单链表是线性表的链式存储实现6.有如下程序 #includeiostreamh int func(int a,int b) return(a+b); void main() int x=2,y=5,z=8,r; r=func (func (x,y),z); coutr; 该程序的输出的结果是(分数:2.00)A.12B.13C.14D.157.下面程序的结果是 #in
3、cludeiostreamh class A int a; public: A():a(1) void showa()couta; ; class B int a; public: B():a(2) void showa()couta; ;class C:public A,public B int a; public: C():a(3) voidshowa()couta; ; voidmain() C c; cshowa(); (分数:2.00)A.1B.2C.3D.程序有错误8.在数据流图(DFD)中,带有名字的箭头表示(分数:2.00)A.模块之间的调用关系B.程序的组成成分C.控制程序的
4、执行顺序D.数据的流向9.下列程序的输出结果是 #includeiostreamh class Myclass public:My class(inti=0,int j=0) x=i; y=j; void show()cout“x=“ x“ “ “y=“ yendl; void show()constcout“x=“y=“yendl; privated: int x; int y; ; void main() Myclassmy1(3,4); const my2(7,8); mylshow();my2show();(分数:2.00)A.x=4,y=3;x=7,y=8B.x=3,y=4;X=7,
5、y=8C.x=7,y=8;x=4,y=3D.x=8,y=7;x=7,y=810.下列描述中,抽象类的特性是(分数:2.00)A.可以说明虚函数B.可以定义友元函数C.可以进行构造函数重载D.不能说明其对象11.关于 C+语言与 C语言关系描述中错误的是(分数:2.00)A.C+语言是 C语言的超集B.C+语言对 C浯言进行了扩充C.C+语言包含 C语言的全部语法特征D.C+语言与 C语言都是面向对象的程序设计语言12.下列数据模型中,具有坚实理论基础的是(分数:2.00)A.层次模型B.网状模型C.关系模型D.以上 3个都是13.假设线性表的长度为 n,则在最坏情况下,冒泡排序需要的比较次数为
6、(分数:2.00)A.log2nB.n2C.O(n1.5)D.n(n1)/214.关于二义性的描述错误的是(分数:2.00)A.一个子类的两个父类中都有某个同名成员,在子类中对该成员访问可能出现二义性B.解决二义性可以用对成员名的限定法C.父类和子类中同时出现同名函数,也可能存在二义性D.一个子类是从两个父类派生出来的,而这两个父类又有一个共同的父类,对该父类成员进行访问时,可能出现二义性15.分布式数据库系统不具有的特点是(分数:2.00)A.数据分布性和逻辑整体性B.位置透明性和复制透明性C.分布性D.数据冗余16.有以下程序 #includeiostreamh void fun(int
7、a,int b,int c) a=456,b=567,c=678; void main() int x=10,y=20,z=30; fun(x,y,2); cout X , y , z endl; 输出结果是(分数:2.00)A.30,20,10B.10,20,30C.456,567,678D.678,567,45617.下列程序的运行结果是 #includeiostreamh void fun(int*a,int*b) int*k; k=a;a=b;b=k; void main() int a=3,b=6,*x=B.int* const p;C.const int*const p;D.int
8、*p;30.以下程序中调用 cin函数给变量 a输人数值的方法是错误的,其错误原因是 #includeiostreamh void main() int*p,*q,a,b; p= void show()cout“x=“ x“ “ “y=“ yendl; void show()constcout“x=“y=“yendl; privated: int x; int y; ; void main() Myclassmy1(3,4); const my2(7,8); mylshow();my2show();(分数:2.00)A.x=4,y=3;x=7,y=8 B.x=3,y=4;X=7,y=8C.x=
9、7,y=8;x=4,y=3D.x=8,y=7;x=7,y=8解析:解析 在 Myclass类中定义了两个同名函数 show,其中一个是常成员函数。在 main函数中定义了两个对象 myl,my2,其中对象 my2是常对象。这两个对象调用成员函数 show时,通过对象 myl调用的是没有用,const 修饰的一般成员函数,而通过对象 my2调用的是 const修饰的常成员函数。10.下列描述中,抽象类的特性是(分数:2.00)A.可以说明虚函数B.可以定义友元函数C.可以进行构造函数重载D.不能说明其对象 解析:解析 带有纯虚函数的类称为抽象类,抽象类中的纯虚函数没有具体的定义,所以不能说明抽象
10、类的对象。11.关于 C+语言与 C语言关系描述中错误的是(分数:2.00)A.C+语言是 C语言的超集B.C+语言对 C浯言进行了扩充C.C+语言包含 C语言的全部语法特征D.C+语言与 C语言都是面向对象的程序设计语言 解析:解析 C 语言是一种面向过程的程序设计语言,而 C+语言是一种面向对象的设计语言,C +语言是 C语言的超集,它包含了 C语言的所有语言特性,并进行了扩充。12.下列数据模型中,具有坚实理论基础的是(分数:2.00)A.层次模型B.网状模型C.关系模型 D.以上 3个都是解析:解析 关系模型较之格式化模型(网状模型和层次模型)有以下方面的优点,即数据结构比较简单、具有
11、很高的数据独立性、可以盲接处理多对多的联系,以及有坚实的理论基础。13.假设线性表的长度为 n,则在最坏情况下,冒泡排序需要的比较次数为(分数:2.00)A.log2nB.n2C.O(n1.5)D.n(n1)/2 解析:解析 假设线性表的长度为 n,则在最坏情况下,冒泡排序要经过 n/2遍的从前往后的扫描和 n/2遍的从后往前的扫描,需要的比较次数为 n(n- 1)/2。14.关于二义性的描述错误的是(分数:2.00)A.一个子类的两个父类中都有某个同名成员,在子类中对该成员访问可能出现二义性B.解决二义性可以用对成员名的限定法C.父类和子类中同时出现同名函数,也可能存在二义性 D.一个子类是
12、从两个父类派生出来的,而这两个父类又有一个共同的父类,对该父类成员进行访问时,可能出现二义性解析:解析 基类和其继承类同时出现同名函数,则在继承类中实现对象中调用该函数是使用继承类中的定义,这种情况下是不会产生二义性的。15.分布式数据库系统不具有的特点是(分数:2.00)A.数据分布性和逻辑整体性B.位置透明性和复制透明性C.分布性D.数据冗余 解析:解析 分布式数据库系统具有数据分布性、逻辑整体性、位置透明性和复制透明性的特点,其数据也是分布的;但分布式数据库系统中数据经常重复存储,数据也并非必须重复存储,主要视数据的分配模式而定。若分配模式是一对多,即一个片段分配到多个场地存放,则是冗余
13、的数据库,否则是非冗余的数据库。16.有以下程序 #includeiostreamh void fun(int a,int b,int c) a=456,b=567,c=678; void main() int x=10,y=20,z=30; fun(x,y,2); cout X , y , z endl; 输出结果是(分数:2.00)A.30,20,10B.10,20,30 C.456,567,678D.678,567,456解析:解析 本题:考查函数中变量的作用范围,在主函数中给变量 x,y,z 赋值,然后将其作为实参传递给了函数 fun(),虽然在函数 fun()中改变了这 3个变量的值
14、,但只是同名的局部变量,不影响函数中变量的值,所以在凋用函数 fun()结束后,主函数 3个变量的值未改变。17.下列程序的运行结果是 #includeiostreamh void fun(int*a,int*b) int*k; k=a;a=b;b=k; void main() int a=3,b=6,*x= t=x; x=y; y=t 如果在 main函数中用 swap(a,b),会有什么结果呢?在函数调用开始时,a 的值传送给 x,b 的值传递给 y。执行完 swap()函数后,x 和 y的值是互换了,但 main()函数中的 a和 b并未互换。也就是说由于“单向传递”的“值传递”方式,形
15、参值的改变无法传递给实参。 为了使在函数中改变了的变量值能被main()函数所闻,不能采取上述办法,而应该用指针变量做函数参数。布函数执行过程中使指针变量所指向的变量值发生变化,函数调用结束后,这些变量值的变化被保留下来,这样就实现了调用函数改变变量的值,在主凋函数中使用这些改变了的值的目的。 swap(int*p1,int*p2) int p; p= *p1; *p1 =*P2; *p2=p; 注意交换*P1 和*p2 的值是如何实现的,如果写成下面这样就有问题了! swap(int*P1,int*p2) int*P; *p=*P1;/*此语句有问题*/ *p1=*p2; *p2=*p: *
16、p1 就是 a,是整型变量。而*p 是指针变量 p所指向的变量,但 p中并无确切地址,用*p 可能会造成破坏系统的正常工作状态。应该将*p1 的值赋给一个整型变量,用整型变量作为过渡变量实现*P1 和*p2 的交换。18.软件工程的出现是由于(分数:2.00)A.程序设计方法学的影响B.软件产业化的需要C.软件危机的出现 D.计算机的发展解析:解析 软件工程概念的出现源自于软件危机。为了消除软件危机,通过认真研究解决软件危机的方法,认识到软件工程是使计算机软件走向了程科学的途径,逐步形成了软件工程的概念。19.下列语句的输出结果 coutstrlen(“/t/,/065/xff/n“);(分数
17、:2.00)A.5 B.14C.8D.输出项不合法,无正常输出解析:解析 该字符串中包含的字符是/t (跳格符)、/“(双引号)、/065(ASCII 值为八进制 065,也即十进制为 51的字符)、/xff(ASCII 值为十六进制 ff,也即十进制为 255的字符)、/n(换行符)。20.在 C+语言中,打开一个文件就是将这个文件与一个什么建立关联?(分数:2.00)A.流 B.类C.结构D.对象解析:解析 C+的 I/O系统是通过一种称为流的机制来实现文件和控制台的 I/O操作。简单地说,在C+中,输入输出操作是通过流来完成的。而文件流以磁盘文件以及其他可按文件方式进行管理的外部设备为输
18、入输出对象。每个文件流都应当与一个打开的文件相联系;关闭一个文件就是取消这种联系。21.this指针是 C+语言实现什么的一种机制?(分数:2.00)A.抽象B.封装 C.继承D.重载解析:解析 this 指针是 C+语言实现封装的一种机制,它将对象和该对象调用的成员函数连接在一起,在外部看来,每一个对象都拥有自己的函数成员。22.线性表 L=(a1,a2,a3,ai,an),下列说法正确的是(分数:2.00)A.每个元素都有一个直接前件和直接后件B.线性表中至少要有一个元素C.表中诸元素的排列顺序必须是由小到大或由大到小D.除第一个元素和最后一个元素外,其余每个元素都有一个且只有一个直接前件
19、和直接后件 解析:解析 线性表可以为主表;第一个元素没有直接前件,最后一个元素没有直接后件;线性表的定义中,元素的排列并没有规定大小顺序。23.算法分析的目的是(分数:2.00)A.找出数据结构的合理性B.找出算法中输入和输出之间的关系C.分析算法的易懂性和可靠性D.分析算法的效率以求改进 解析:解析 算法分析是指对一个算法的运行时间和占用空间做定量的分析,一般计算出相应的数量级,常用时间复杂度和空间复杂度表示。分析算法的目的就是要降低算法的时间复杂度和空间复杂度,提高算法的执行效率。24.下面的语句中错误的是(分数:2.00)A.int a=5;int x ; B.const int a=5
20、;int x ;C.int n=5;int*p=new int;D.const int n = 5;int *p = new int;解析:解析 在 C+中定义数组时,数组的范围参数在静态定义时必须是一个常数,而在动态分配内存定义时可以是常数,也可以是一个赋了值得参数。故选项 A)是错误的定义方法。25.如果表达式 x*y+2中,“*”是作为友元函数重载的,“+”是作为友元函数重载的,则该表达式还可为(分数:2.00)A.operator+(operator*(x, B.operator+(operator*(x,C.operator*(operator+(x,D.operator+(oper
21、ator*(x,)解析:解析 C+中用成员函数重载 x*y为:xoperator*(y),用友元函数重载 x*y为:operator *(x,y),用成员函数重载 x+y为:xoperator+(y),用友元函数重载 x+y为:operator+(x,y)。26.假定 int类型变量占用两个字节,其有定义 int x 10;0,2,4;,则数组 x在内存中所占字节数是(分数:2.00)A.3B.6C.10D.20 解析:解析 x 数组共有 10个元素,在花括弧内只提供 3个初值,这表示只给前面的 3个成员赋值,后7个元素的值为 0,所以,一共有 20个字节。27.在 C+语言中,不合法的实型数
22、据的是(分数:2.00)A.0.123B.123e3C.2.1e3.5 D.123.0解析:解析 在 C+语言中,实数有两种形式表示,即十进制数形式和指数形式,在指数形式中, e3,2le3.5,e3,e 等都是不合法的指数形式。再如 123e3 或 123E3都代表 123乘以 10的 3次方。注意,字母 e的前面必须有数字,且 e的后面必须是整数。28.对于语句 coutsetfill(*)setw(10)1setfill(*)setw(2) 2;的输出结果是(分数:2.00)A.* * * * * * * * *1 *2 B.* * * * * * * *12C.* * * * * *
23、*1 *2D.12* * * * * * * *解析:解析 C+语言中 setfill的意思是在空格的地方填上 setfill函数中的参数字符,setw 的意思是设置整个输出字符串的字符个数,本题中用。宋代替空格。29.下列定义中 p指向的地址可更改,但*p 不能够更改的是(分数:2.00)A.const int* p; B.int* const p;C.const int*const p;D.int*p;解析:解析 const int*p;是只能改变指针地址,int*const p;是只能改变*p 的内容,const int* const P;是指针的地址和*p 的内容都不能改变,int *
24、 p;是两者都能改变。30.以下程序中调用 cin函数给变量 a输人数值的方法是错误的,其错误原因是 #includeiostreamh void main() int*p,*q,a,b; p=&a; cout”input a:”; cinp; (分数:2.00)A.*p表示的是指针变量 p的地址B.p表示的是变量 a的地址,而不是变量 a的值 C.*p表示的是指针变量 p的值D.*p只能用来说明 p是一个指针变量解析:解析 p 表示的是变量 a的地址,定义后*p 表示的是变量 a的值。31.关系表中的每一横行称为一个(分数:2.00)A.元组 B.字段C.属性D.码解析:解析 关系表中,每一
25、行称为一个元组,对应表中的一条记录;每一列称为表中的一个属性,对应表中的一个字段;在二维表中儿能惟一标识元组的最小属性集称为该表的键或码。32.函数模板:templateclass T T add(T x,T y)return x+y; 下列对 add函数的调用不正确的是(分数:2.00)A.add(1,2)B.addint(1,2)C.add(1,0,2) D.add(10,20)解析:解析 对于 templateclass T Tadd(T x,T y)return x+y; 调用时可以省略模板实参的声明,但是要求 x和 y的数据类型必须是一样的。33.执行语句 for(i=1;i+4;)
26、;,后变量 i的值是(分数:2.00)A.3B.4C.5 D.不定解析:解析 for 语句中的表达式可以部分或全部省略,但两个“;”不能省略,若 3个表达式均省略,会因为缺少条件判断,导致循环无限执行,而形成死循环。本题中当 i的值为 5的时候,循环终止。34.若有如下语句 #includeiostreamh void main() int x=3: do X=X-2; coutX; while(!(-x); 则上面程序段(分数:2.00)A.输出的是 1B.输出的是 1和-2 C.输出的是 3和 0D.是死循环解析:解析 dowhile 语句的一般格式为 do循环体语句 while(表达式)
27、;,先执行循环体语句一次,再判断表达式的值,若为真则继续执行循环,否则终止循环。本题中,先执行 x=x-2,即为 l。判断表达式的值,!(-x)为真,x=0,继续循环。再次执行循环体语句后,x=-2,此时表达式的值为 0,结束循环。35.下列字符串中可以用作 C+语言标识符的是(分数:2.00)A._1234 B.foobarC.virtualD.34var解析:解析 C+语言标识符只能由数字,字母和下划线组成,并且只能以字母和下划线为开头。二、B填空题/B(总题数:13,分数:26.00)36.在算法正确的前提下,评价一个算法的两个标准是U 【1】 /U。(分数:2.00)填空项 1:_ (
28、正确答案:时间复杂度和空间复杂度)解析:37.将代数式 z= (分数:2.00)填空项 1:_ (正确答案:SQRT(x2+y2)/(a+b))解析:38.软件危机出现于 60年代末,为了解决软件危机,人们提出了U 【3】 /U的原理来设计软件,这就是软件工程诞生的基础。(分数:2.00)填空项 1:_ (正确答案:软件工程学)解析:39.U【4】 /U是数据库设计的核心。(分数:2.00)填空项 1:_ (正确答案:数据模型)解析:解析 数据模型是对客观事物及联系的数据描述,它反映了实体内部及实体与实体之间的联系。因此,数据模型是数据库设计的核心。40.在关系模型中,把数据看成一个二维表,每
29、一个二维表称为一个U 【5】 /U。(分数:2.00)填空项 1:_ (正确答案:关系)解析:解析 在关系模型中,把数据看成一个二维表,每一个二维表称为一个关系,表中的每一列称为一个属性,相当于记录中的个数据项,对属性的命名称为属性名;表中的一行称为一个元组,相当于记录值。41.一个 C+语言程序的开发步骤通常包括编辑、U 【6】 /U、链接、运行和调试。(分数:2.00)填空项 1:_ (正确答案:编译)解析:解析 C+语言程序开发的基本步骤是编辑、编译、链接、运行和调试。42.若已知 a=10,b=20,则表达式!ab 的值为U 【7】 /U。(分数:2.00)填空项 1:_ (正确答案:
30、1)解析:解析 计算表达式!ab,先计算!a,因 a的值为 10,!a 的值为 0。关系表达式 020 为真,所以表达式!ab,的值为 1。43.下面程序的运行结果是U 【8】 /U和 U【9】 /U。 #includeiostreamh #define N 10 #defines(x)X*X #define f(x)(X*X) void main() int il,i2; i1=1000/s(N);i2=1000/f(N); cout i1 “ “ i2; (分数:2.00)填空项 1:_ (正确答案:81000)解析:910 解析 对于 define宏定义语句,系统会在编译前进行替换。本题
31、替换过程如下: i1=1000/s(N) i1=1000/s(10) i1=1000/10*10 i1=1000 i2=1000/f(N) i2=1000/f(10) i2=1000/(10*10) i2=1044.友元类的所有成员函数都是另一个类的U 【10】 /U。(分数:2.00)填空项 1:_ (正确答案:友元函数)解析:解析 C+语言中友元类中的函数都是另一个类的友元函数。45.U【11】 /U是实现 c+语言编译时多态性的机制,U 【12】 /U是实现 C+语言运行时多态性的机制。(分数:2.00)填空项 1:_ (正确答案:11静态联编或静态绑定)解析:12动态联编或动态绑定 解
32、析 C+语言编译时多态性的机制是静态绑定,实现 C+语言运行时多态性的机制是动态绑定。46.表达式 xoperator+()还可写成U 【13】 /U。(分数:2.00)填空项 1:_ (正确答案:+x)解析:解析 C +语言中用成员函数重载+x 为 xoperator+()用友元函数重载+x 为:operator+(x)47.以下程序的输出结果是U 【14】 /U。 #includeiostreamh void main() int a=0; a+ =(a=8) ; couta; (分数:2.00)填空项 1:_ (正确答案:16)解析:解析 解答本题的关键是要分析清楚表达式 a+= (a=8)中,a 的值已经被赋为 8,而不是 0。48.若要在 C盘根目录下作为二进制文件打开文件 testdat,则应该用的语句是U 【15】 /U。(分数:2.00)填空项 1:_ (正确答案:if stream 且 fin(“C:/testdat”,ios_binary);或 if stream fin,;finopen(c:/testdat“,ios_binary);)解析:解析 C+中打开文件有两种方式if stream fin (“testdat”);if stream fin; finopen(“testdat”);,ios_binary 的意义是以二进制文件打开。