1、二级 C+笔试 301及答案解析(总分:100.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.下面关于友元函数的叙述中,不正确的是( )。(分数:2.00)A.友元函数提供了类之间数据共享的一个途径B.一个友元函数可以访问任何类的任何成员C.友元函数破坏了数据的封装D.友元函数增加了程序设计的灵活性2.假定 MyClass为一个类,则该类的拷贝构造函数的声明语句为 ( )。(分数:2.00)A.MyClassclass sampleprivate: int x; static int y;public: sample(int a); static void
2、print(sample s);sample: sample(int a) x=a; y+=x;void sample: print(sample s) cout“x=“s. x“,y=“yend1;int sample: y=0;int main() sample s1(10); sample s2(20); sample: print(s2); return 0;程序运行后的输出结果是( )。(分数:2.00)A.x=10,y=20B.x=20,y=30C.x=30,y=20D.x=30,y=306.有如下程序:#includeiostream.hvoid main()int x=1,a=
3、0,b=0;switch (x)Case 0: b+;Case 1: a+;Case 2: a+; b+;cout“a=“a“,“b=“ b;该程序的输出结果是( )。(分数:2.00)A.a=2,b=1B.a=1,b=1C.a=1,b=0D.a=2,b=27.对下列程序段的描述正确的是( )。#includeiostream.hint Fun(int, int); void main();coutFun(5,50)end1;int Fun(int x, int y)return x*x+ y*y;(分数:2.00)A.该函数定义正确,但函数调用方式错误B.该函数调用方式正确,但函数定义错误C
4、.该函数定义和调用方式都正确D.该函数定义和调用方式都错误8.关于虚函数下面说的正确的是( )。(分数:2.00)A.若在重定义虚函数时使用了 virtual,则该重定义函数还是虚函数B.虚函数不能声明为友元C.子类必须重定义父类的虚函数D.虚函数不能是 static的9.软件开发离不开系统环境资源的支持,其中必要的测试数据属于( )。(分数:2.00)A.硬件资源B.通信资源C.支持软件D.辅助资源10.下列描述中正确的是( )。(分数:2.00)A.程序就是软件B.软件开发不受计算机系统的限制C.软件既是逻辑实体,又是物理实体D.软件是程序、数据与相关文档的集合11.下列叙述中正确的是(
5、)。(分数:2.00)A.一个算法的空间复杂度大,则其时间复杂度也必定大B.一个算法的空间复杂度大,则其时间复杂度必定小C.一个算法的时间复杂度大,则其空间复杂度必定小D.上述三种说法都不对12.有如下函数模板声明:templatetypename TT Max(Ta,Tb)return(a=b)?a: b;下列对函数模板 Max()的调用中错误的是( )。(分数:2.00)A.Max(3.5,4.5)B.Max(3.5,4)C.Maxdouble(3.5,4.5)D.Maxdouble(3.5,4)13.下列说法中错误的是( )。(分数:2.00)A.公有继承时基类中的 public成员在派
6、生类中仍是 public成员B.私有继承时基类中的 protected成员在派生类中仍是 protected成员C.私有继承时基类中的 public成员在派生类中是 private成员D.保护继承时基类中的 public成员在派生类中是 protected成员14.下列关于输入流类成员函数 getline()的描述中,错误的是( )。(分数:2.00)A.该函数是用来读取键盘输入的字符串的B.该函数读取的字符串长度是受限制的C.该函数读取字符串时,遇到终止符便停止D.该函数读取字符串时,可以包含空格15.下面是关于 ios类的叙述,正确的是( )。(分数:2.00)A.它是 istream类和
7、 ostream类的虚基类B.它只是 istream类的虚基类C.它只是 ostream类的虚基类D.它是 iostream类的虚基类16.友元运算符 obj1obj2 被 C+编译器解释为( )。(分数:2.00)A.operator(obj1,obj2)B.(obj1,obj2)C.obj2.operator(obj1)D.obj1.operator(obj2)17.下面程序的运行结果是( )。#include iostream.hvoid main()int x=10, y=A;x%=y+ 1;coutxend1;(分数:2.00)A.0B.1C.2D.318.编制一个好的程序首先要确保
8、它的正确性和可靠性,还应强调良好的编程风格。在选择标识符的名字时应考虑( )。(分数:2.00)A.名字长度越短越好,以减少源程序的输入量B.多个变量共用一个名字,以减少变量名的数目C.选择含义明确的名字,以正确提示所代表的实体D.尽量用关键字作名字,以使名字标准化19.有如下程序:#include iostream#include iomanipusing namespace std;int main()cout.fill(*);coutleftsetw(4)123 “OK“end1;return 0;执行这个程序的输出结果是( )。(分数:2.00)A.123*OKB.123*OK*C.*
9、123OKD.*123*OK20.有如下程序#include iostream#include iomanipusing namespace std; class MyClass public:MyClass() coutA; MyClass(char c) coutc; MyClass() coutB; ;int main() MyClass p1,*p2;p2=new MyClass(X);delete p2;return 0;执行这个程序屏幕上将显示输出( )。(分数:2.00)A.ABXB.ABXBC.AXBD.AXBB21.如果表达式-x/y 中的“-”和“/”都是作为友元函数重载的
10、运算符,采用运算符函数调用格式,该表达式还可表示( )。(分数:2.00)A.operator/( operator-(),B.operator/(operator-(,C.operator-().operator/(D.operator/(operator-()22.如果表达式 y*x+中,“”是作为成员函数重载运算符,“+”是作为友元函数重的运算符,采用运算符函数调用格式,该表达式还可表示为( )。(分数:2.00)A.operator+(0)operator*(B.openrator*(operator+(0),C.operator*(openrator+(x,0)D.operator*
11、(operator+(x,0),23.对如下二叉树 (分数:2.00)A.ABCDEFB.DBEAFCC.ABDECFD.DEBFCA24.有如下类定义:class Pointint x_, y_;public:Point(): x_(0), y_(0) Point(int x, int y =0): x_(x), y_(y) 若执行语句 Point a(2),b3, *c4;则 Point 类的构造函数被调用的次数是( )。(分数:2.00)A.2次B.3次C.4次D.5次25.以下程序段的输出结果是( )。int x = 5;do coutx-end1;while(!x);(分数:2.00
12、)A.5B.无任何输出C.4D.陷入死循环26.下列函数中对调用它的函数没有起到任何作用的是( )。(分数:2.00)A.void f1(double B.double f2(double return x-1.5;C.void f3(double -x;D.double f4(double *-*x; return*x;27.语句 ofstream f (“SALARY.DAT“,ios_ base: app);的功能是建立流对象 f,并试图打开文件 SALARY.DAT 与 f关联,而且( )。(分数:2.00)A.若文件存在,将其置为空文件:若文件不存在,打开失败B.若文件存在,将文件指
13、针定位于文件尾;若文件不存在,建立一个新文件C.若文件存在,将文件指针定位于文件首;若文件不存在,打开失败D.若文件存在,打开失败:若文件不存在,建立一个新文件28.在设计程序时,应采纳的原则之一是( )。(分数:2.00)A.不限制 goto语句的使用B.减少或取消注解行C.程序越短越好D.程序结构应有助于读者理解29.在长度为 64的有序线性表中进行顺序查找,最坏情况下需要比较的次数为( )。(分数:2.00)A.63B.64C.6D.730.从工程管理角度,软件设计一般分为两步完成,它们是( )。(分数:2.00)A.概要设计与详细设计B.数据设计与接口设计C.软件结构设计与数据设计D.
14、过程设计与数据设计31.有如下类声明: class XA int x;public: XA(int n) x=n;class XB: public XA int y;public: XB(int a, int b);在构造函数朋的下列定义中,正确的是( )。(分数:2.00)A.XB:XB(int a,int : x(,y(B.XB:XB (int a,int :XA(,y(C.XB:XB(int a,int : x(,XB(D.XB:XB(int a,int :XA(,XB(32.下列有关继承和派生的叙述中,正确的是( )。(分数:2.00)A.如果一个派生类私有继承其基类,则该派生类对象不
15、能访问基类的保护成员B.派生类的成员函数可以访问基类的所有成员C.基类对象可以赋值给派生类对象D.如果派生类没有实现基类的一个纯虚函数,则该派生类是一个抽象类33.在 C+中,打开一个文件,就是将这个文件与一个( )建立关联,关闭一个文件,就是取消这种关联。(分数:2.00)A.类B.流C.对象D.结构34.类模板 templateclass Tclass x.,其中,友元函数 f对特定类型 T(如 int),使函数 f(xint);成为 xint模板类的友元,则其说明为( )。(分数:2.00)A.friend void f();B.friend void f(xT);C.friend vo
16、id A: f()D.friend void CD: f(xT);35.下列叙述中正确的是( )。(分数:2.00)A.线性链表是线性表的链式存储结构B.栈与队列是非线性结构C.双向链表是非线性结构D.只有根结点的二叉树是线性结构二、B填空题/B(总题数:15,分数:30.00)36.对长度为 10的线性表进行冒泡排序,最坏情况下需要比较的次数为U 【1】 /U。(分数:2.00)填空项 1:_37.在树中,度为零的结点称为U 【2】 /U。(分数:2.00)填空项 1:_38.按“先进先出”原则组织数据的数据结构是U 【3】 /U。(分数:2.00)填空项 1:_39.数据结构分为线性结构和
17、非线性结构,线性表、栈和队列都属于U 【4】 /U。(分数:2.00)填空项 1:_40.冒泡排序算法在最好的情况下的元素交换次数为U 【5】 /U。(分数:2.00)填空项 1:_41.若有整型变量 x=2,则表达式 x2 的结果是U 【6】 /U。(分数:2.00)填空项 1:_42.重载的运算符仍然保持其原来的操作数个数、优先级和U 【7】 /U不变。(分数:2.00)填空项 1:_43.C+在重载运算中,如用成员函数重载一元运算符参数表中需要U 【8】 /U个参数,如用友元函数重载一元运算符参数表中需要 1个参数。(分数:2.00)填空项 1:_44.若有以下程序: #include
18、iostream using namespace std; class Base public: void who() cout“Base“end1; ; class Derivedl: public Base public: void who() cout“Derived“end1; ; int main() Base *p; Derived1 obj1; p= p-who(); return 0; 则该程序运行后的输出结果是U 【9】 /U。(分数:2.00)填空项 1:_45.如果类中的一个成员函数的定义实现在类内,则该函数系统自动默认为该类的U 【10】 /U函数。(分数:2.00)填
19、空项 1:_46.类是一个支持集成的抽象数据类型,而对象是类的U 【11】 /U。(分数:2.00)填空项 1:_47.下列程序的输出结果是U 【12】 /U。 #include iostream using namespace std; int main() int i=5; int r=7; coutiend1; return 0; (分数:2.00)填空项 1:_48.写出下列程序的运行结果U 【13】 /U。 #include iostream.h. #include fstream.h #include stdlib.h void main() fstream outfile, in
20、file; outfile.open(“data.clat“, ios: out); if(!outfile) cout“Cant open the file.“end1; abort(); outfile“ 1234567890“end1; outfile“aaaaaaaaa“end1; outfile“*“end1; outfile.close(); infile.open(“data. dat “, ios: in); if(!infile) cout“Cant open the file.“end1; abort(); char line80; int I=0; while(!infi
21、le. eof() I+; infile.getline(line, sizeof(line); coutI“:“lineend1; infile.close(); (分数:2.00)填空项 1:_49.在下面程序的横线处填上适当的内容,使程序执行后的输出结果为 ABCD。 #include iostream using namespace std; class A public: A() coutA; ; class B: U【14】 /U public: B()coutB; class C: virtual public A public: C()coutC; class D:public
22、 B, public C public: D() coutD; ; void main() D obj; (分数:2.00)填空项 1:_50.下列程序的输出结果是U 【15】 /U。 #include iostream using namespace std; class A int a; public: A():a(9) virtual void print() const couta; ; ; class B: public A char b; public: B()b=S; void print() const cout b; ; void show(A int main() A d1
23、,*p; B d2; p= dl1.print(); d2.print(); p-print(); show(d1);show(d2); return 0; (分数:2.00)填空项 1:_二级 C+笔试 301答案解析(总分:100.00,做题时间:90 分钟)一、B选择题/B(总题数:35,分数:70.00)1.下面关于友元函数的叙述中,不正确的是( )。(分数:2.00)A.友元函数提供了类之间数据共享的一个途径B.一个友元函数可以访问任何类的任何成员 C.友元函数破坏了数据的封装D.友元函数增加了程序设计的灵活性解析:2.假定 MyClass为一个类,则该类的拷贝构造函数的声明语句为
24、( )。(分数:2.00)A.MyClassclass sampleprivate: int x; static int y;public: sample(int a); static void print(sample s);sample: sample(int a) x=a; y+=x;void sample: print(sample s) cout“x=“s. x“,y=“yend1;int sample: y=0;int main() sample s1(10); sample s2(20); sample: print(s2); return 0;程序运行后的输出结果是( )。(分
25、数:2.00)A.x=10,y=20B.x=20,y=30 C.x=30,y=20D.x=30,y=30解析:6.有如下程序:#includeiostream.hvoid main()int x=1,a=0,b=0;switch (x)Case 0: b+;Case 1: a+;Case 2: a+; b+;cout“a=“a“,“b=“ b;该程序的输出结果是( )。(分数:2.00)A.a=2,b=1 B.a=1,b=1C.a=1,b=0D.a=2,b=2解析:7.对下列程序段的描述正确的是( )。#includeiostream.hint Fun(int, int); void main
26、();coutFun(5,50)end1;int Fun(int x, int y)return x*x+ y*y;(分数:2.00)A.该函数定义正确,但函数调用方式错误B.该函数调用方式正确,但函数定义错误C.该函数定义和调用方式都正确 D.该函数定义和调用方式都错误解析:8.关于虚函数下面说的正确的是( )。(分数:2.00)A.若在重定义虚函数时使用了 virtual,则该重定义函数还是虚函数B.虚函数不能声明为友元C.子类必须重定义父类的虚函数D.虚函数不能是 static的 解析:9.软件开发离不开系统环境资源的支持,其中必要的测试数据属于( )。(分数:2.00)A.硬件资源B.
27、通信资源C.支持软件D.辅助资源 解析:10.下列描述中正确的是( )。(分数:2.00)A.程序就是软件B.软件开发不受计算机系统的限制C.软件既是逻辑实体,又是物理实体D.软件是程序、数据与相关文档的集合 解析:11.下列叙述中正确的是( )。(分数:2.00)A.一个算法的空间复杂度大,则其时间复杂度也必定大B.一个算法的空间复杂度大,则其时间复杂度必定小C.一个算法的时间复杂度大,则其空间复杂度必定小D.上述三种说法都不对 解析:12.有如下函数模板声明:templatetypename TT Max(Ta,Tb)return(a=b)?a: b;下列对函数模板 Max()的调用中错误
28、的是( )。(分数:2.00)A.Max(3.5,4.5)B.Max(3.5,4) C.Maxdouble(3.5,4.5)D.Maxdouble(3.5,4)解析:13.下列说法中错误的是( )。(分数:2.00)A.公有继承时基类中的 public成员在派生类中仍是 public成员B.私有继承时基类中的 protected成员在派生类中仍是 protected成员 C.私有继承时基类中的 public成员在派生类中是 private成员D.保护继承时基类中的 public成员在派生类中是 protected成员解析:14.下列关于输入流类成员函数 getline()的描述中,错误的是(
29、)。(分数:2.00)A.该函数是用来读取键盘输入的字符串的 B.该函数读取的字符串长度是受限制的C.该函数读取字符串时,遇到终止符便停止D.该函数读取字符串时,可以包含空格解析:15.下面是关于 ios类的叙述,正确的是( )。(分数:2.00)A.它是 istream类和 ostream类的虚基类 B.它只是 istream类的虚基类C.它只是 ostream类的虚基类D.它是 iostream类的虚基类解析:16.友元运算符 obj1obj2 被 C+编译器解释为( )。(分数:2.00)A.operator(obj1,obj2) B.(obj1,obj2)C.obj2.operator
30、(obj1)D.obj1.operator(obj2)解析:17.下面程序的运行结果是( )。#include iostream.hvoid main()int x=10, y=A;x%=y+ 1;coutxend1;(分数:2.00)A.0 B.1C.2D.3解析:18.编制一个好的程序首先要确保它的正确性和可靠性,还应强调良好的编程风格。在选择标识符的名字时应考虑( )。(分数:2.00)A.名字长度越短越好,以减少源程序的输入量B.多个变量共用一个名字,以减少变量名的数目C.选择含义明确的名字,以正确提示所代表的实体 D.尽量用关键字作名字,以使名字标准化解析:19.有如下程序:#inc
31、lude iostream#include iomanipusing namespace std;int main()cout.fill(*);coutleftsetw(4)123 “OK“end1;return 0;执行这个程序的输出结果是( )。(分数:2.00)A.123*OK B.123*OK*C.*123OKD.*123*OK解析:20.有如下程序#include iostream#include iomanipusing namespace std; class MyClass public:MyClass() coutA; MyClass(char c) coutc; MyCla
32、ss() coutB; ;int main() MyClass p1,*p2;p2=new MyClass(X);delete p2;return 0;执行这个程序屏幕上将显示输出( )。(分数:2.00)A.ABXB.ABXBC.AXBD.AXBB 解析:21.如果表达式-x/y 中的“-”和“/”都是作为友元函数重载的运算符,采用运算符函数调用格式,该表达式还可表示( )。(分数:2.00)A.operator/( operator-(),B.operator/(operator-(, C.operator-().operator/(D.operator/(operator-()解析:22
33、.如果表达式 y*x+中,“”是作为成员函数重载运算符,“+”是作为友元函数重的运算符,采用运算符函数调用格式,该表达式还可表示为( )。(分数:2.00)A.operator+(0)operator*(B.openrator*(operator+(0),C.operator*(openrator+(x,0) D.operator*(operator+(x,0),解析:23.对如下二叉树 (分数:2.00)A.ABCDEFB.DBEAFCC.ABDECFD.DEBFCA 解析:24.有如下类定义:class Pointint x_, y_;public:Point(): x_(0), y_(0
34、) Point(int x, int y =0): x_(x), y_(y) 若执行语句 Point a(2),b3, *c4;则 Point 类的构造函数被调用的次数是( )。(分数:2.00)A.2次B.3次C.4次 D.5次解析:25.以下程序段的输出结果是( )。int x = 5;do coutx-end1;while(!x);(分数:2.00)A.5 B.无任何输出C.4D.陷入死循环解析:26.下列函数中对调用它的函数没有起到任何作用的是( )。(分数:2.00)A.void f1(double B.double f2(double return x-1.5;C.void f3(
35、double -x; D.double f4(double *-*x; return*x;解析:27.语句 ofstream f (“SALARY.DAT“,ios_ base: app);的功能是建立流对象 f,并试图打开文件 SALARY.DAT 与 f关联,而且( )。(分数:2.00)A.若文件存在,将其置为空文件:若文件不存在,打开失败B.若文件存在,将文件指针定位于文件尾;若文件不存在,建立一个新文件 C.若文件存在,将文件指针定位于文件首;若文件不存在,打开失败D.若文件存在,打开失败:若文件不存在,建立一个新文件解析:28.在设计程序时,应采纳的原则之一是( )。(分数:2.0
36、0)A.不限制 goto语句的使用B.减少或取消注解行C.程序越短越好D.程序结构应有助于读者理解 解析:29.在长度为 64的有序线性表中进行顺序查找,最坏情况下需要比较的次数为( )。(分数:2.00)A.63B.64 C.6D.7解析:30.从工程管理角度,软件设计一般分为两步完成,它们是( )。(分数:2.00)A.概要设计与详细设计 B.数据设计与接口设计C.软件结构设计与数据设计D.过程设计与数据设计解析:31.有如下类声明: class XA int x;public: XA(int n) x=n;class XB: public XA int y;public: XB(int
37、a, int b);在构造函数朋的下列定义中,正确的是( )。(分数:2.00)A.XB:XB(int a,int : x(,y(B.XB:XB (int a,int :XA(,y( C.XB:XB(int a,int : x(,XB(D.XB:XB(int a,int :XA(,XB(解析:32.下列有关继承和派生的叙述中,正确的是( )。(分数:2.00)A.如果一个派生类私有继承其基类,则该派生类对象不能访问基类的保护成员B.派生类的成员函数可以访问基类的所有成员C.基类对象可以赋值给派生类对象D.如果派生类没有实现基类的一个纯虚函数,则该派生类是一个抽象类 解析:33.在 C+中,打开
38、一个文件,就是将这个文件与一个( )建立关联,关闭一个文件,就是取消这种关联。(分数:2.00)A.类B.流 C.对象D.结构解析:34.类模板 templateclass Tclass x.,其中,友元函数 f对特定类型 T(如 int),使函数 f(xint);成为 xint模板类的友元,则其说明为( )。(分数:2.00)A.friend void f();B.friend void f(xT); C.friend void A: f()D.friend void CD: f(xT);解析:35.下列叙述中正确的是( )。(分数:2.00)A.线性链表是线性表的链式存储结构 B.栈与队列
39、是非线性结构C.双向链表是非线性结构D.只有根结点的二叉树是线性结构解析:二、B填空题/B(总题数:15,分数:30.00)36.对长度为 10的线性表进行冒泡排序,最坏情况下需要比较的次数为U 【1】 /U。(分数:2.00)填空项 1:_ (正确答案:45)解析:37.在树中,度为零的结点称为U 【2】 /U。(分数:2.00)填空项 1:_ (正确答案:叶子结点)解析:38.按“先进先出”原则组织数据的数据结构是U 【3】 /U。(分数:2.00)填空项 1:_ (正确答案:队列 或 Queue)解析:39.数据结构分为线性结构和非线性结构,线性表、栈和队列都属于U 【4】 /U。(分数
40、:2.00)填空项 1:_ (正确答案:线性结构)解析:40.冒泡排序算法在最好的情况下的元素交换次数为U 【5】 /U。(分数:2.00)填空项 1:_ (正确答案:0)解析:41.若有整型变量 x=2,则表达式 x2 的结果是U 【6】 /U。(分数:2.00)填空项 1:_ (正确答案:8)解析:42.重载的运算符仍然保持其原来的操作数个数、优先级和U 【7】 /U不变。(分数:2.00)填空项 1:_ (正确答案:结合性)解析:43.C+在重载运算中,如用成员函数重载一元运算符参数表中需要U 【8】 /U个参数,如用友元函数重载一元运算符参数表中需要 1个参数。(分数:2.00)填空项
41、 1:_ (正确答案:0)解析:44.若有以下程序: #include iostream using namespace std; class Base public: void who() cout“Base“end1; ; class Derivedl: public Base public: void who() cout“Derived“end1; ; int main() Base *p; Derived1 obj1; p= p-who(); return 0; 则该程序运行后的输出结果是U 【9】 /U。(分数:2.00)填空项 1:_ (正确答案:Derived)解析:45.如果
42、类中的一个成员函数的定义实现在类内,则该函数系统自动默认为该类的U 【10】 /U函数。(分数:2.00)填空项 1:_ (正确答案:内联)解析:46.类是一个支持集成的抽象数据类型,而对象是类的U 【11】 /U。(分数:2.00)填空项 1:_ (正确答案:实例)解析:47.下列程序的输出结果是U 【12】 /U。 #include iostream using namespace std; int main() int i=5; int r=7; coutiend1; return 0; (分数:2.00)填空项 1:_ (正确答案:7)解析:48.写出下列程序的运行结果U 【13】 /
43、U。 #include iostream.h. #include fstream.h #include stdlib.h void main() fstream outfile, infile; outfile.open(“data.clat“, ios: out); if(!outfile) cout“Cant open the file.“end1; abort(); outfile“ 1234567890“end1; outfile“aaaaaaaaa“end1; outfile“*“end1; outfile.close(); infile.open(“data. dat “, ios
44、: in); if(!infile) cout“Cant open the file.“end1; abort(); char line80; int I=0; while(!infile. eof() I+; infile.getline(line, sizeof(line); coutI“:“lineend1; infile.close(); (分数:2.00)填空项 1:_ (正确答案:1: 1234567890)解析:2:aaaaaaaaa 3:* 4:49.在下面程序的横线处填上适当的内容,使程序执行后的输出结果为 ABCD。 #include iostream using namespace std; class A public: A() coutA; ; class B: U【14】 /U public: B()coutB; class C: virtual public A public: C()coutC; class D:public B, public C public: D() coutD; ; void main() D obj; (分数:2.00)填空项 1:_ (正确答案:virtual public A)解析:50.下列程序的输出结果是U 【15】 /U。 #include iostream usin