C程序设计试题及答案Word下载.docx
- 文档编号:19411503
- 上传时间:2023-01-06
- 格式:DOCX
- 页数:15
- 大小:20.45KB
C程序设计试题及答案Word下载.docx
《C程序设计试题及答案Word下载.docx》由会员分享,可在线阅读,更多相关《C程序设计试题及答案Word下载.docx(15页珍藏版)》请在冰豆网上搜索。
C.intprint(char);
D.voidprint(int,int);
11.在下列成对的表达式中,运算结果类型相同的一对是(D)
A.7/2和7.0/2.0
B.7/2.0和7/2
C.7.0/2和7/2
D.7.0/2.0和7.0/2
l2.内联函数的特点是(D)
A.减少代码量,加快访问速度B.减少代码量,减缓访问速度
C.增加代码量,减缓访问速度D.增加代码量,加快访问速度
13.类的私有成员可在何处被访问(A)
A.本类的成员函数中
B.本类及子类的成员函数中
C.通过对象名在任何位置
D.不可访问
14.类的构造函数在以下什么情况下会被自动调用(B)
A.定义成员函数时
B.定义对象时
C.定义数据成员时
D.定义友元函数时
15.下列关于析构函数描述正确的是(D)
A.可以重载B.函数体中必须有delete语句
C.返回类型必须是void类型
D.不能指定返回类型
16.设有函数TSum(Tx,Ty){returnx+y;
},其中T为模板类型,则下列语句中对该函数错误的使用是(D)
A.Sum(1,2);
B.Sum(3.0,2.2);
C.Sum(‘A’,‘C’);
D.Sum("
A"
,"
C"
);
17.下列哪个编译指令属于条件编译指令(C)
A.#includeB.#defineC.#elseD.#pragma
18.关于类的静态成员函数描述错误的是(A)
A.在创建对象前不存在
B.不能说明为虚函数
C.不能直接访问非静态函数
D.不是对象的成员
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++语句是cout<
<
a。
22.C++将数据从一个对象流向另一个对象的流动抽象为“流”,从流中获取数据的操作称为提取操作。
23.执行下列代码
intb=100;
cout<
"
Hex:
hex<
b;
程序的输出结果是Hex:
64。
24.静态联编所支持的多态性称为编译时或编译的多态性。
25.C++程序必须有且只有一个主函数,其函数名为main。
26.写出声明一个复数对象的语句,并使该对象被初始化为2.2+1.3i,此声明语句是complex<
float>
num(2.2,1.3)或complex<
double>
num(2.2,1.3)。
27.若有函数定义为:
intadd(intml=0,intm2=2,intm3=4)
{returnml+m2+m3;
}
在主函数中有ints=add
(1)+add(0,1)+add(0,1,2);
则执行此语句后s的值为1528。
28.C++中使用inline关键字说明函数为内联函数。
29.在源程序中有宏定义:
#definePI3.14,则若不想使该宏定义影响到程序的其它地方,可以使用#undefPI删除该宏定义。
30.类和其它数据类型不同的是,组成这种类型的不仅可以有数据,还可以有对数据进行操作的函数或成员函数。
31.有下列代码inta=0;
doubleb=0;
cin>
>
a>
当用键盘输入1.25时,b=0.25。
32.对于类Point而言,其析构函数的定义原型为Point:
:
~Point()或~Point()。
33.对象成员构造函数的调用顺序取决于这些对象在类中说明的顺序,与它们在成员初始化列表中给出的顺序无关。
34.类的简单成员函数是指声明中不含const、volatile、static关键字的函数。
35.与操作对象的数据类型相互独立的算法称为泛型算法。
36.从一个或多个以前定义的类产生新类的过程称为派生。
37.在vector类中向向量尾部插入一个对象的方法是push_back(constT&
)。
38.C++中用于动态创建对象,并返回该对象的指针的关键字是new。
39.C++的流类库预定义的与标准输出设备相联接的流是cout。
40.执行下列代码
cout<
noshowpoint<
123.0;
程序输出结果是123。
三、改错题(本大题共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;
}
return(x<
x:
y;
该语句求的是最小值,应改为return(x>
或return(x<
y:
x;
42.#include<
classtest{
intx;
test(inta){x=a;
voidset(inta){x=a;
voidget(){cout<
x<
}
main(){
consttesta(3);
a.set(5);
a.get();
a.set(5);
a是常对象,不能被更新
或consttesta(3);
去掉const使a不再为常对象
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);
print(pointa){cout<
endl;
}print()不是成员函数不允许直接调用a.x或将private:
floatx,y;
改为public:
或cour<
改为a.getx();
44.#include<
intx,y;
fl(inta,intb){x=a;
voidprint(){cout<
fa;
a.f1(1.5,1.8);
a.print();
a.f1(1.5,1.8);
f1()调用时实参与形参类型不一致
45.#include<
intx=6;
constint*p=x;
*p<
constint*p=x;
变量给指针p赋值必须加上&
四、完成程序题(本大题共5小题,每小题4分,共20分)
46.完成下面程序,使其输出l0,并在退出运行时正确释放分配给指针的存储空间。
#include<
iostream>
usingnamespacestd;
voidmain()
{
int*a,*p;
a=newint(10);
p=_a_;
deletep;
或deletea;
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();
b=d;
baseb1=b;
或base&
b1=b;
或baseb1(6);
b1.showbase();
base*pb=&
bl;
pb—>
showbase();
输出结果如下:
x=3
x=6,y=7
x=6
48.下面程序的运行结果如下:
B:
:
display()
C:
在下划线处填上缺少的部分。
源程序如下:
#include<
classB
virtualvoiddisplay(){cout<
"
B:
display()"
classC:
publicB
voiddisplay(){cout<
C:
display()"
voidfun(B*p)
p—>
display();
Bb,*pb;
Cc;
pb=&b;
fun(pb);
pb=&c;
49.下面程序的运行结果如下:
Thisisline1
Thisisline2
Thisisline3
fstream或”fstream”
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.eof())
fin.getline(str,100);
cout<
str<
fin.close();
50.在下划线处填上缺少的部分。
#include<
template<
classT>
或template<
typenameT>
Tfun(Tx)
Ty;
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();
originaldate:
2008,January1
Converteddate:
1January2008
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();
x=1,y=2
x=70,y=80
53.给出下面程序的输出结果
#include"
iostream.h"
intmain()
inti=17;
while(i>
=10)
if(--i%4==3)continue;
else
i="
i--<
i=16i=14i=12i=10
54.给出下面程序的输出结果
intnum=300;
int&
ref=num;
ref;
ref=ref-100;
num;
num=num-50;
ref<
300200150
六、程序设计题(本大题共1小题,共10分)
55.定义堆栈类模板Stack(先进后出),栈的大小由使用者确定。
要求该类模板对外提供
如下二种基本操作:
(1)push入栈
(2)pop出栈,用数组来实现
template<
classT,intsize>
classStack{
Tx[size];
intcurrent;
Stack(){current=0;
....push(....);
....pop(....);
};
请写出两个函数的过程(如果需要形式参数,请给出形参类型和数量,以及返回值类型)
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文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 程序设计 试题 答案