1、C+程序设计试题和答案1C+程序设计试题一、单项选择题(本大题共20小题.每小题1分.共20分)在每小题列出的四个备选项中只有一个是符合题目要求的.请将其代码填写在题后的括号内。错选、多选或未选均无分。+源程序文件扩展名为( A )A.cpp B.h C.1ib D.obj2.在C+中使用流进行输入输出.其中专用于从键盘进行输入的流是( B ) 3.包含自定义头文件的预处理指令是( D )A.#define B.#include C.#define D.#include4.用于标识十六进制前缀或后缀是( D )A.元 B.后缀L或e C.前缀零 D.前缀0x5.设存在整型变量int x.则下列
2、句与其它三项含义不同的是( A )* p=&x; & p=x; & p=x; &p=x;6.在定义类成员时.为产生封装性.则需使用哪个关键字( D ) 7.设函数void swap(int&.int&)将交换两形参的值.如两整型变量int a=10;int b=15;则执行swap后.a、b值分别为( C ) 函数默认参数在函数原型中说明.默认参数必须放在参数序列的( C )A.前部 B.中部 C.后部 D.两端9.设存在函数int min返回两参数中较小值.若求三者中最小值.下列表达式中错误的是( B ) m=min(min.min); m=min; m=min); m =min(min.1
3、6);10.下列函数不能和函数void print(char)构成重载的是( C ) print(int); print; print(char); print;11.在下列成对的表达式中.运算结果类型相同的一对是( D )2和 和72 和72 和2 l2.内联函数的特点是( D )A.减少代码量.加快访问速度 B.减少代码量.减缓访问速度C.增加代码量.减缓访问速度 D.增加代码量.加快访问速度13.类的私有成员可在何处被访问( A )A.本类的成员函数中 B.本类及子类的成员函数中C.通过对象名在任何位置 D.不可访问14.类的构造函数在以下什么情况下会被自动调用( B )A.定义成员函数
4、时 B.定义对象时C.定义数据成员时 D.定义友元函数时15.下列关于析构函数描述正确的是( D )A.可以重载 B.函数体中必须有delete语句C.返回类型必须是void类型 D.不能指定返回类型 16.设有函数T Sum(T y)return x+y;.其中T为模板类型.则下列语句中对该函数错误的使用是( D ); ;(A.C); (A.C);17.下列哪个编译指令属于条件编译指令( C )A.#include B.#define C.#else D.#pragma18.关于类的静态成员函数描述错误的是( A ) A.在创建对象前不存在 B.不能说明为虚函数C.不能直接访问非静态函数 D
5、.不是对象的成员l9.如果类A被声明成类B的友元.则( D ) A.类A的成员即类B的成员 B.类B的成员即类A的成员C.类A的成员函数不得访问类B的成员 D.类B不一定是类A的友元20.派生类的对象可以访问以下那种情况继承的基类成员( D ) A.私有继承的私有成员 B.公有继承的私有成员C.私有继承的保护成员 D.公有继承的公有成员二、填空题(本大题共20小题.每小题1分.共20分)请在每小题的空格中填上正确答案。错填、不填均无分。21.若使用标准输出流把整型变量a的值输出到屏幕上.实现此操作的C+语句是 couta 。+将数据从一个对象流向另一个对象的流动抽象为“流”.从流中获取数据的操
6、作称为 提取操作 。23.执行下列代码 int b=100; coutHex:hexb; 程序的输出结果是Hex:64。24.静态联编所支持的多态性称为编译时或编译的多态性。+程序必须有且只有一个主函数.其函数名为main。26.写出声明一个复数对象的语句.并使该对象被初始化为+.此声明语句是complex num,或complex num,。27.若有函数定义为: int add(int ml= m2= m3=4) return ml+m2+m3; 在主函数中有int s=add(1)+add+add;则执行此语句后s的值为15 28。+中使用inline关键字说明函数为内联函数。29.在源
7、程序中有宏定义:#define PI .则若不想使该宏定义影响到程序的其它地方.可以使用#undef PI删除该宏定义。30.类和其它数据类型不同的是.组成这种类型的不仅可以有数据.还可以有对数据进行操作的函数或成员函数。31.有下列代码int a=0;double b=0;cinab;当用键盘输入时.b=。32.对于类Point而言.其析构函数的定义原型为Point:Point( )或Point( )。33.对象成员构造函数的调用顺序取决于这些对象在类中说明的顺序.与它们在成员初始化列表中给出的顺序无关。34.类的简单成员函数是指声明中不含const、volatile、static关键字的函
8、数。35.与操作对象的数据类型相互独立的算法称为泛型算法。36.从一个或多个以前定义的类产生新类的过程称为派生。37.在vector类中向向量尾部插入一个对象的方法是push_back(const T&)。+中用于动态创建对象.并返回该对象的指针的关键字是new。+的流类库预定义的与标准输出设备相联接的流是cout。40.执行下列代码coutnoshowpoint;程序输出结果是123 。三、改错题(本大题共5小题.每小题2分.共10分)下面的类定义中有一处错误.请用下横线标出错误所在行并给出修改意见。41.#include class f private:float ; public:f(f
9、loat b)x=a;y=b; float max()return(xy)x:y; 求最大值 ; main( ) f a; cout( )endl; return(xy)x:y;或return(xy)y:x;42.#include class test private:int x; public:test(int a)x=a; void set(int a)x=a; void get()coutxendl; main() const test a(3);(5);();(5); a是常对象.不能被更新或const test a(3);去掉const使a不再为常对象43.#include clas
10、s point private:float ; public:f1(float b)x=a;y=b; point()x=0;y=0; void getx()coutxendl; void gety()coutyendl; ; void print(point a)coutendl; main() point a; print(a);print(point a)coutendl; print( )不是成员函数不允许直接调用或将private:float x,y;改为 public:float x,y;或courendl;改为 ( );44.#include class f private:int
11、 ; public:fl(int b)x=a;y=b; void print()coutxyendl; ; main() f a; ;();,; f1( )调用时实参与形参类型不一致45.#include main() int x=6; const int*p=x; cout*pendl; const int *p=x; 变量给指针p赋值必须加上&四、完成程序题(本大题共5小题.每小题4分.共20分)46.完成下面程序.使其输出l0.并在退出运行时正确释放分配给指针的存储空间。#include using namespace std;void main()int *a.*p;a=new int
12、(10);p= _a_;cout*pendl;delete p;或delete a;47.#include using namespace std; class base private:int x; public:base(int a)x=a; int get()return x; void showbase() coutx=xendl; ; class Derived:public base private:int y; public:Derived(int b):base(a)y=b; void showderived() coutx=get().y=yshowbase(); (); (
13、);输出结果如下:x=3x=7x=6x=6x=6x=7x=648.下面程序的运行结果如下: B:display() C:display() 在下划线处填上缺少的部分。源程序如下: #include using namespace std; class B public: virtual void display( ) cout B:display( ) endl; ; class C:public B public:void display()coutC:display()display(); void main() B b.*pb; C c; pb=b; fun(pb); pb=c; fun
14、(pb); 49.下面程序的运行结果如下: This is line1 This is line2 This is line3 在下划线处填上缺少的部分。源程序如下: #include #includefstream或”fstream” using namespace std; void main() fstream fin, fout; (.ios:out); if(!() return; for(int i=0;i3;i=i+1) foutThis is linei+1endl; (); (.ios:in); if(! () return; char str100; while(!( )
15、; coutstrendl; (); 50.在下划线处填上缺少的部分。源程序如下: #include using namespace std;template或template T fun(T x) T y; y=x*x-T(5); return y; void main() float a=2; coutfun(a);五、程序分析题(本大题共4小题.每小题5分.共20分)51.请写出文本文件中的内容#include#include using namespace std;#includevoid main() ofstream myFile1;();coutEnter the data in
16、 Chinese format. . 25):endl;string Date( 1);string Year=;int k=(.);int i=( );string Month=(k+;string Day=(i+;string NewDate=Day+ +Month+ +Year;myFileloriginal date:Dateendl;myFile1Converted date:NewDateendl;();original date:2008,January 1 Converted date:1 January 200852.给出下面程序的输出结果#include using nam
17、espace std;class Simpleint ;public:Simple()x=y=0;Simple(int j)x=i;y=j;void copy(Simples);void setxy(int j)x=i;y=j;void print()coutx=x.y=y=10) if(-i4=3)continue; else couti=i-endl; i=16 i=14 i=12 i=1054.给出下面程序的输出结果 #include using namespace std; void main() int num=300; int &ref=num; coutref; ref=ref-
18、100; cout num; num=num-50; cout refendl; 300 200 150六、程序设计题(本大题共1小题.共10分)55.定义堆栈类模板Stack(先进后出).栈的大小由使用者确定。要求该类模板对外提供 如下二种基本操作: (1)push入栈(2)pop出栈.用数组来实现 #include using namespace std; template class Stack T xsize; int current; public: Stack()current=0; .push(.); .pop(.); ;请写出两个函数的过程(如果需要形式参数.请给出形参类型和数量.以及返回值类型)void Satck:push(T t) if (current= =size) cout“The Stack is full!”endl;exit(0); /堆栈满则程序结束else xcurrent=t;current+; /新元素入栈并修改栈顶指针T Stack:pop( ) if (current= =0)cout”There is no object in the Stack!”endl;exit(0); /堆栈空则程序结束else T a=xcurrent-1;current-;returna; /栈顶元素出栈并修改栈顶指针
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1