09年C++自考试题Word文档格式.docx
- 文档编号:21156226
- 上传时间:2023-01-28
- 格式:DOCX
- 页数:15
- 大小:21.09KB
09年C++自考试题Word文档格式.docx
《09年C++自考试题Word文档格式.docx》由会员分享,可在线阅读,更多相关《09年C++自考试题Word文档格式.docx(15页珍藏版)》请在冰豆网上搜索。
D.intm=min(min(47,26),16);
10.下列函数不能和函数voidprint(char)构成重载的是()
A.intprint(int);
B.voidprint(char,char);
C.intprint(char);
D.voidprint(int,int);
11.在下列成对的表达式中,运算结果类型相同的一对是()
A.7/2和7.0/2.0B.7/2.0和7/2
C.7.0/2和7/2D.7.0/2.0和7.0/2
l2.内联函数的特点是()
A.减少代码量,加快访问速度B.减少代码量,减缓访问速度
C.增加代码量,减缓访问速度D.增加代码量,加快访问速度
13.类的私有成员可在何处被访问()
A.本类的成员函数中B.本类及子类的成员函数中
C.通过对象名在任何位置D.不可访问
14.类的构造函数在以下什么情况下会被自动调用()
A.定义成员函数时B.定义对象时
C.定义数据成员时D.定义友元函数时
15.下列关于析构函数描述正确的是()
A.可以重载B.函数体中必须有delete语句
C.返回类型必须是void类型D.不能指定返回类型
16.设有函数TSum(Tx,Ty){returnx+y;
},其中T为模板类型,则下列语句中对该函数错误的使用是()
A.Sum(1,2);
B.Sum(3.0,2.2);
C.Sum(‘A’,‘C’);
D.Sum("
A"
,"
C"
);
17.下列哪个编译指令属于条件编译指令()
A.#includeB.#define
C.#elseD.#pragma
18.关于类的静态成员函数描述错误的是()
A.在创建对象前不存在B.不能说明为虚函数
C.不能直接访问非静态函数D.不是对象的成员
l9.如果类A被声明成类B的友元,则()
A.类A的成员即类B的成员
B.类B的成员即类A的成员
C.类A的成员函数不得访问类B的成员
D.类B不一定是类A的友元
20.派生类的对象可以访问以下那种情况继承的基类成员()
A.私有继承的私有成员B.公有继承的私有成员
C.私有继承的保护成员D.公有继承的公有成员
二、填空题(本大题共20小题,每小题1分,共20分)
请在每小题的空格中填上正确答案。
错填、不填均无分。
21.若使用标准输出流把整型变量a的值输出到屏幕上,实现此操作的C++语句是______。
22.C++将数据从一个对象流向另一个对象的流动抽象为“流”,从流中获取数据的操作称为______。
23.执行下列代码
intb=100;
cout<
<
"
Hex:
hex<
b;
程序的输出结果是______。
24.静态联编所支持的多态性称为______的多态性。
25.C++程序必须有且只有一个主函数,其函数名为______。
26.写出声明一个复数对象的语句,并使该对象被初始化为2.2+1.3i,此声明语句是______。
27.若有函数定义为:
intadd(intml=0,intm2=2,intm3=4)
{returnml+m2+m3;
}
在主函数中有ints=add
(1)+add(0,1)+add(0,1,2);
则执行此语句后s的值为______。
28.C++中使用______关键字说明函数为内联函数。
29.在源程序中有宏定义:
#definePI3.14,则若不想使该宏定义影响到程序的其它地方,可以使用______删除该宏定义。
30.类和其它数据类型不同的是,组成这种类型的不仅可以有数据,还可以有对数据进行操作的_______。
31.有下列代码inta=0;
doubleb=0;
cin>
>
a>
当用键盘输入1.25时,b=______。
32.对于类Point而言,其析构函数的定义原型为______。
33.对象成员构造函数的调用顺序取决于这些对象在类中说明的顺序,与它们在成员初始化列表中给出的顺序______。
34.类的简单成员函数是指声明中不含______、volatile、static关键字的函数。
35.与操作对象的数据类型相互独立的算法称为______。
36.从一个或多个以前定义的类产生新类的过程称为______。
37.在vector类中向向量尾部插入一个对象的方法是______。
38.C++中用于动态创建对象,并返回该对象的指针的关键字是______。
39.C++的流类库预定义的与标准输出设备相联接的流是______。
40.执行下列代码
noshowpoint<
123.0;
程序输出结果是______。
三、改错题(本大题共5小题,每小题2分,共10分)
下面的类定义中有一处错误,请用下横线标出错误所在行并给出修改意见。
41.#include<
iostream.h>
classf{
private:
floatx,y;
public:
f(floata,floatb){x=a;
y=b;
floatmax(){return(x<
y)?
x:
y;
}//求最大值
};
main(){
fa(1.5,3.8);
a.max()<
endl;
}
42.#include<
classtest{
intx;
test(inta){x=a;
voidset(inta){x=a;
voidget(){cout<
x<
main(){
consttesta(3);
a.set(5);
a.get();
43.#include<
classpoint{
f1(floata,floatb){x=a;
point(){x=0;
y=0;
voidgetx(){cout<
voidgety(){cout<
y<
};
voidprint(pointa){cout<
a.x<
pointa;
a.f1(3.0,5.0);
print(a);
44.#include<
intx,y;
fl(inta,intb){x=a;
voidprint(){cout<
fa;
a.f1(1.5,1.8);
a.print();
45.#include<
intx=6;
constint*p=x;
*p<
四、完成程序题(本大题共5小题,每小题4分,共20分)
46.完成下面程序,使其输出l0,并在退出运行时正确释放分配给指针的存储空间。
#include<
iostream>
usingnamespacestd;
voidmain()
{
int*a,*p;
a=newint(10);
p=______;
cout<
__________
47.#include<
usingnamespacestd;
classbase
{
base(inta){x=a;
intget(){returnx;
voidshowbase(){cout<
x="
classDerived:
publicbase
{private:
inty;
Derived(inta,intb):
base(a){y=b;
voidshowderived()
{cout<
get()<
,y="
voidmain()
baseb(3);
Derivedd(6,7);
b.showbase();
d.showderived();
________;
b1.showbase();
base*pb=&
bl;
pb—>
showbase();
输出结果如下:
x=3
x=6,y=7
x=6
48.下面程序的运行结果如下:
B:
:
display()
C:
在下划线处填上缺少的部分。
源程序如下:
#include<
classB
______display(){cout<
"
B:
display()"
classC:
publicB
_______display(){cout<
C:
display()"
voidfun(B*p)
p—>
display();
Bb,*pb;
Cc;
pb=&b;
fun(pb);
pb=&c;
49.下面程序的运行结果如下:
Thisisline1
Thisisline2
Thisisline3
#include<
#include_____
fstreamfin,fout;
fout.open("
my.txt"
,ios:
out);
if(!
fout.is_open())
return;
for(inti=0;
i<
3;
i=i+1)
fout<
Thisisline"
i+1<
fout.close();
fin.open("
in);
fin.is_open())
charstr[100];
while(______)
fin.getline(str,100);
str<
fin.close();
50.在下划线处填上缺少的部分。
________
Tfun(Tx)
______y;
y=x*x-T(5);
returny;
floata=2;
fun(a);
五、程序分析题(本大题共4小题,每小题5分,共20分)
51.请写出myTextl.txt文本文件中的内容
#include<
string>
fstream>
voidmain()
ofstreammyFile1;
myFilel.open("
myTextl.txt"
EnterthedatainChineseformat(e.g.,2008,May25):
stringDate("
2008,January1"
stringYear=Date.substr(0,4);
intk=Date.find("
inti=Date.find("
stringMonth=Date.substr(k+l,i-k-1);
stringDay=Date.substr(i+1,2);
stringNewDate=Day+"
+Month+"
+Year;
myFilel<
originaldate:
Date<
myFile1<
Converteddate:
NewDate<
myFilel.close();
52.给出下面程序的输出结果
classSimple
public:
Simple(){x=y=0;
Simple(inti,intj){x=i;
y=j;
voidcopy(Simple&s);
voidsetxy(inti,intj){x=i;
voidprint(){cout<
};
voidSimple:
copy(Simple&s)
x=s.x;
y=s.y;
voidfunc(Simples1,Simple&s2)
s1.setxy(30,40);
s2.setxy(70,80);
Simpleobj1(1,2),obj2;
obj2.copy(obj1);
func(obj1,obj2);
obj1.print();
obj2.print();
53.给出下面程序的输出结果
#include"
iostream.h"
intmain()
inti=17;
while(i>
=10)
if(--i%4==3)continue;
else
i="
i--<
54.给出下面程序的输出结果
intnum=300;
int&
ref=num;
ref;
ref=ref-100;
num;
num=num-50;
ref<
六、程序设计题(本大题共1小题,共10分)
55.定义堆栈类模板Stack(先进后出),栈的大小由使用者确定。
要求该类模板对外提供
如下二种基本操作:
(1)push入栈
(2)pop出栈,用数组来实现
template<
classT,intsize>
classStack{
Tx[size];
intcurrent;
Stack(){current=0;
....push(....);
....pop(....);
};
请写出两个函数的过程(如果需要形式参数,请给出形参类型和数量,以及返回值类型)
参考答案
一、单项选择题
1.A2.B3.D4.D5.A6.D7.C8.C9.B10.C
11.D12.D13.A14.B15.D16.D17.C18.A19.D20.D
二、填空题
21.cout<
a;
22.提取操作
23.Hex:
6424.编译时或编译
25.mainplex<
float>
num(2.2,1.3)或complex<
double>
num(2.2,1.3)
27.1528.inline
29.#undefPI30.函数或成员函数
31.0.2532.Point:
:
~Point()或~Point()
33.无关34.const
35.泛型算法36.派生
37.push_back(constT&
)38.new
39.cout40.123
三、改错题
41.return(x<
x:
y;
该语句求的是最小值,应改为return(x>
或return(x<
y:
x;
42.a.set(5);
a是常对象,不能被更新
或consttesta(3);
去掉const使a不再为常对象
43.print(pointa){cout<
endl;
}print()不是成员函数不允许直接调用a.x
或将private:
floatx,y;
改为public:
或将cour<
改为a.getx();
44.a.f1(1.5,1.8);
f1()调用时实参与形参类型不一致
45.constint*p=x;
变量给指针p赋值必须加上&
四、完成程序题
46.a;
deletep;
或deletea;
47.b=d;
baseb1=b;
或base&
b1=b;
或baseb1(6);
48.virtualvoidvoid
49.<
或”fstream”!
fin.eof()
50.template<
classT>
或template<
typenameT>
T
五、程序分析题
51.originaldate:
2008,January1
Converteddate:
1January2008
52.x=1,y=2
x=70,y=80
53.i=16
i=14
i=12
i=10
54.300200150
六、程序设计题
55.
voidSatck<
T,size>
push(Tt){
if(current==size){
“TheStackisfull!
”<
exit(0);
}//堆栈满则程序结束
else{x[current]=t;
current++;
}//新元素入栈并修改栈顶指针
TStack<
pop(){
if(current==0){
”ThereisnoobjectintheStack!
}////堆栈空则程序结束
else{Ta=x[current-1];
current--;
returna;
}//栈顶元素出栈并修改栈顶指针
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 09 C+ 自考 试题