1、C+程序设计试题C+程序设计试题 一、单项选择题(本大题共20小题,每小题1分,共20分)在每小题列出的四个备选项中只有一个是符合题目要求的,请将其代码填写在题后的括号内。错选、多选或未选均无分。1对C+语言和C语言的兼容性,描述正确的是( A )AC+兼容C BC+部分兼容C CC+不兼容C DC兼容C+2在C+中使用流进行输入输出,其中用于屏幕输出的对象是( C )Acerr Bcin Ccout Dcfilecerr:标准错误输出;cin:标准输入3对使用关键字new所开辟的动态存储空间,释放时必须使用( C )Afree Bcreate Cdelete Drealse4如没有使用pri
2、vate关键字定义类的数据成员,则默认为( A )Aprivate Bpublic Cprotected Dfriend5使用值传递方式将实参传给形参,下列说法正确的是( A )A形参是实参的备份 B实参是形参的备份 C形参和实参是同一对象 D形参和实参无联系6在函数调用时,如某一默认参数要指明一个特定值,则有( A )A其之前所有参数都必须赋值 B其之后所有参数都必须赋值C其前、后所有参数都必须赋值 D其前、后所有参数都不必赋值7设存在函数int max(int,int)返回两参数中较大值,若求22,59,70三者中最大值,下列表达式不正确的是( C )Aint m = max(22,max
3、(59,70); Bint m = max(max(22,59),70);Cint m = max(22,59,70); Dint m = max(59,max(22,70);8下列哪个类型函数不适合声明为内联函数( A )A函数体语句较多 B函数体语句较少 C函数执行时间较短 D函数执行时间过长9int Func(int,int);不可与下列哪个函数构成重载( B )Aint Func(int,int,int); Bdouble Func(int,int);Cdouble Func(double,double); Ddouble Func(int,double);说明:不能以形参名来区分函数
4、;不能以函数返回值来区分函数。必须是形参的个数或者类型不同才能构成函数重载。10对类中声明的变量,下列描述中正确的是( C )A属于全局变量 B只属于该类 C属于该类,某些情况下也可被该类不同实例所共享D任何情况下都可被该类所有实例共享11类的私有成员可在何处访问( D )A通过子类的对象访问 B本类及子类的成员函数中 C通过该类对象访问 D本类的成员函数中12如果没有为一个类定义任何构造函数的情况下,下列描述正确的是( A )A编译器总是自动创建一个不带参数的构造函数B这个类没有构造函数C这个类不需要构造函数D该类不能通过编译13一个类可包含析构函数的个数是( B )A0个 B1个 C至少一
5、个 D0个或多个只有一个,多了编译器都不知道调用哪个好。而构造函数可以有多个,因为构造函数调用时编译器可以根据变量的类型和数量来确定调用哪个构造函数 ,而析构函数是系统调用的,不能做到这种效果。14this指针存在的目的是( B )A保证基类公有成员在子类中可以被访问B保证每个对象拥有自己的数据成员,但共享处理这些数据成员的代码C保证基类保护成员在子类中可以被访问D保证基类私有成员在子类中可以被访问15下列关于类的权限的描述错误的是( A )A类本身的成员函数只能访问自身的私有成员B类的对象只能访问该类的公有成员C普通函数不能直接访问类的公有成员,必须通过对象访问D一个类可以将另一个类的对象作
6、为成员16在编译指令中,宏定义使用哪个指令( B )A#include B#define C#if D#else17设类A将其它类对象作为成员,则建立A类对象时,下列描述正确的是( B )AA类构造函数先执行 B成员构造函数先执行 C两者并行执行 D不能确定类的组合,描述的是一个类内嵌其他类的对象作为成员的情况,它们之间的关系是一种包含与被包含的关系。在声明一个组合类的对象时,不仅它自身的构造函数将被调用,而且还将调用其内嵌对象的构造函数。这时构造函数的调用顺序是: (1)按照内嵌对象在组合类的声明中出现的次序,依次调用内嵌对象的构造函数; (2)执行本类构造函数的函数体 析构函数的调用执行顺
7、序与构造函数刚好相反。18下列描述错误的是( A )A在创建对象前,静态成员不存在 B静态成员是类的成员C静态成员不能是虚函数 D静态成员函数不能直接访问非静态成员说明:静态成员函数可以直接访问该类的静态数据和函数成员,而访问非静态成员,必须通过参数传递方式得到对象名,然后通过对象名来访问。19对于友元描述正确的是( B )A友元是本类的成员函数 B友元不是本类的成员函数C友元不是函数 D友元不能访问本类私有成员20在哪种派生方式中,派生类可以访问基类中的protected成员( B )Apublic和private Bpublic和protected Cprotected和private D
8、仅protected二、填空题(本大题共20小题,每小题1分,共20分)请在每小题的空格中填上正确答案。错填、不填均无分。21设要把一个文件输出流对象myFile与文件“f:myText.txt相关联,所用的C+语句是:_ myFile.open(“f:myText.txt”);_。22C+中ostream类的直接基类是_ ios类_。23运算符 只能用_成员 _运算符来重载,不能用友元运算符来重载。24定义虚函数所用的关键字是_ virtual _。25vector类中用于返回向量中第1个对象的方法是_ front( ) _。26在C+中,利用向量类模板定义一个具有20个char的向量E,其
9、元素均被置为字符t,实现此操作的语句是_ vectorE(20,t) _。27类的继承是指子类继承基类的_数据成员_和成员函数。28不同对象可以调用相同名称的函数,但可导致完全不同的行为的现象称为_多态性或(类的多态性)_。29_ #include _指令指示编译器将一个源文件嵌入到带该指令的源文件之中。30设类A有成员函数void Fun(void);若要定义一个指向类成员函数的指针变量pafn来指向Fun,该指针变量的声明语句是:_ void(A:*pafn)(void);_。31设在程序中使用如下语句申请了一个对象数组:Point * ptr = new Point2;则在需要释放ptr
10、指向的动态数组对象时,所使用的语句是_ delete ptr; _。32在保护派生中,基类权限为Private的成员在派生类中_不可访问_。33类A有如下成员函数int A:fun(double x)return (int) x2;int A:fun(int x)return x*2;设a为类A的对象,在主函数中有int s=afun(6.0)+a.fun(2),则执行该语句后,s的值为_7_。34对象传送的消息一般由3部分组成:接收对象名、调用操作名和_必要的参数_。35将指向对象的指针作为函数参数,形参是对象指针,实参是对象的_地址值 _。36在使用string类的find成员函数来检索主
11、串中是否含有指定的子串时,若在主串中不含指定的子串,find函数的返回值是_ -1_。37在C+中,声明布尔类型变量所用的关键字是_ bool _。38执行下列代码int a=29,b=100;cout setw (3) a b endl;程序的输出结果是:_ 29100_。(2前面有个空格)39执行下列代码cout Hex: hex 255;程序的输出结果为_ Hex:ff _。40C+语言中可以实现输出一个换行符并刷新流功能的操控符是_ endl _。三、改错题(本大题共5小题,每小题2分,共10分)下面的类定义中有一处错误,请用下横线标出错误所在行并给出修改意见。41#includevo
12、id main( ) int x=5,y=6;const int * p=x;*p=y;cout*pendl; *p=y; 指针p所指向的为一常量,不能进行左值操作42#includeclass fprivate:int x,y;public:f1( )x=0;y=0;print( )coutxyendl;;void main( )f a;a.f1(1,1);a.print( ); a.f1(1,1); f1( )调用时实参与形参数量不一致43#include class f private:int x=0,y=0; public:void f1(int a,int b)x=a;y=b; vo
13、id get( )coutxyendl; ; void main( ) f a; a.f1(1,3); a.get ( ); private:int x=0,y=0; 数据成员声明时不允许直接赋值44#include class pointprivate:float x; public:void f(float a)x=a; void f( )x=0; friend float max(point& a,point& b); ; float max(point& a,point& b)return(a.xb.x)? a.x:b.x;void main( ) point a,b; a.f(2.2
14、);b.f(3.3); couta.max(a,b); couta.max(a,b); max()不是类的成员函数,不能用a.max( )方式调用45#include templateclass fprivate:T x,y;public:void f1(T a,T b)x=a;y=b;T max( )retum(xy)?x:y;;void main( )f a;a.f1(1.5,3.8); couta.xa.ya.max( )endl; couta.xa.ya.max()endl; x,y是私有类型,不能在主函数中直接使用四、完成程序题(本大题共5小题,每小题4分,共20分)46完成下面类中
15、的成员函数的定义。 class point private: int m,n; public: point(int,int); point(point&); ; point:point(int a,int b) m=a;_ n _=b; point:point(_point&t _) m=t.m; n=t.n; 47下面是一个输入半径,输出其面积和周长的C+程序,在下划线处填上正确的语句。 #include using namespace std; _ const double _pi=3.14159; void main( ) double r; coutr _ ; double l=2.0
16、*pi*r;double s=pi*r*r;coutn The long is:lendl; coutThe area is:sendl; 48在下划线处填上缺少的部分。 #include #include using namespace std; class complex public: int real; int imag; complex(int r=0,int i=0) real=r; imag=i; ; complex operator+(_ complex&a _,complex& b) int r=a.real+b.real; int i=a.imag+b.imag; retu
17、rn_ complex(r,i) _; void main( ) complex x(1,2),y(3,4),z; z=x+y; coutz.real+z.imagiendl; 49程序的输出结果如下: 1,9 50,30 请根据输出数据在下面程序中的下划线处填写正确的语句。 源程序如下: #include using namespace std; class base private: int m; public: base( ) ; base(int a):m(a) int get( )return m; void set(int a)m=a; ; void main() base*ptr
18、=new base2; ptr- set(30); ptr= _ ptr+1; _; ptr- set(50); base a2=1,9; couta0.get( ),a1.get( )endl; coutget( ),; ptr=ptr-1; coutget( ) _endl; delete ptr; 50在下面横线处填上求两个浮点数之差的cha函数的原型声明、调用方法。 #include using namespace std; void main( ) float a,b; _ float cha(float,float); _函数cha的原型声明 a=12.5; b=6.5; floa
19、t c=_ cha(a,b) _; 调用函数cha coutcendl; float cha(float x,float y) float w; w=x-y; return w; 五、程序分析题(本大题共4小题,每小题5分,共20分)51给出下面程序的输出结果。 #include template class Sample T n; public: Sample(T i)n=i; int operator=(Sample &); ; template int Sample:operator=(Samples) if(n=s.n) return 1; else return 0; void ma
20、in( ) Samplesl(2),s2(3); couts1与s2的数据成员(sl =s2 ?相等:不相等)endl; Samples3(2.5),s4(2.5); couts3与s4的数据成员(s3=s4 ? 相等:不相等)endl; S1与S2的数据成员不相等 S3与S4数据成员相等 52给出下面程序的输出结果。 #include using namespace std; template T max(T ml,T m2) return(m1m2)?ml:m2: void main( ) coutmax(1,7) tmax(2.0,5.0)endl; coutmax(y,btmax(A,
21、a)endl; 7 5y a53给出下面程序的输出结果 #include using namespace std; class A public: int x; A( ) A(int a)x=a; int get(int a)return x+a; ; void main( ) A a(8); int(A:*p)(int); p=A:get; cout(a.*p)(5)endl; A*pi=a; cout*P)(7)endl; 131554给出下面程序的输出结果。 include #include using namespace std; class Book char*title; char
22、*author; int numsold; public: Book( ) Book(const char*strl,const char*str2,const int num) int len=strlen(strl); title=new charlen+1; strcpy(title,str1); len=strlen(str2); author=new charlen+1; strcpy(author,str2); numsold=num; void setbook(const char*str1,const char*str2,const int num) int len=strle
23、n(str1); title=new charlen+1; strcpy(title,str1); len=strlen(str2); author=new charlen+1; strcpy(author,str2); numsold=num; Book( ) delete title; delete author; void print(ostream&output) output书名:titleendl; output作者:authorendl; output月销售量:numsoldendl; ; void main( ) Book obj1(数据结构,严蔚敏,200),obj2; ob
24、j1.print(cout); obj2.setbook(C+语言程序设计,李春葆,210); obj2.print(cout); 月销售量:200书名:c+程序设计作者:李春葆月销售量:210六、程序设计题(本大题共1小题,共10分)55在三角形类TRI实现两个函数,功能是输入三个顶点坐标判断是否构成三角形 #include #include class point private:float x,y; public:point(float a,float b)x=a;y=b; point( )x=0;y=0; , void set(float a,float b)x=a;y=b; float getx( )return x; float gety( )return y; ; class tripoint x,y,z;float s1,s2,s3; public;settri();用于输入三个顶点坐标 test();用于判断是否构成三角
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1