程序的输出结果是Hex:
64。
24.静态联编所支持的多态性称为编译时或编译的多态性。
++程序必须有且只有一个主函数.其函数名为main。
26.写出声明一个复数对象的语句.并使该对象被初始化为+.此声明语句是complexnum,或complexnum,。
27.若有函数定义为:
intadd(intml=m2=m3=4)
{returnml+m2+m3;}
在主函数中有ints=add
(1)+add+add;
则执行此语句后s的值为1528。
++中使用inline关键字说明函数为内联函数。
29.在源程序中有宏定义:
#definePI.则若不想使该宏定义影响到程序的其它地方.可以使用#undefPI删除该宏定义。
30.类和其它数据类型不同的是.组成这种类型的不仅可以有数据.还可以有对数据进行操作的函数或成员函数。
31.有下列代码inta=0;doubleb=0;cin>>a>>b;当用键盘输入时.b=。
32.对于类Point而言.其析构函数的定义原型为Point:
:
~Point()或~Point()。
33.对象成员构造函数的调用顺序取决于这些对象在类中说明的顺序.与它们在成员初始化列表中给出的顺序无关。
34.类的简单成员函数是指声明中不含const、volatile、static关键字的函数。
35.与操作对象的数据类型相互独立的算法称为泛型算法。
36.从一个或多个以前定义的类产生新类的过程称为派生。
37.在vector类中向向量尾部插入一个对象的方法是push_back(constT&)。
++中用于动态创建对象.并返回该对象的指针的关键字是new。
++的流类库预定义的与标准输出设备相联接的流是cout。
40.执行下列代码
cout<程序输出结果是123。
三、改错题(本大题共5小题.每小题2分.共10分)
下面的类定义中有一处错误.请用下横线标出错误所在行并给出修改意见。
41.#include<>
classf{
private:
float;
public:
f(floatb){x=a;y=b;}
floatmax(){return(xx:
y;}//求最大值
};
main(){
fa;
cout<<()<}
return(xx:
y;该语句求的是最小值.应改为return(x>y)?
x:
y;或return(xy:
x;
42.#include<>
classtest{
private:
intx;
public:
test(inta){x=a;}
voidset(inta){x=a;}
voidget(){cout<}
main(){
consttesta(3);
(5);
();
}
(5);a是常对象.不能被更新
或consttesta(3);去掉const使a不再为常对象
43.#include<>
classpoint{
private:
float;
public:
f1(floatb){x=a;y=b;}
point(){x=0;y=0;}
voidgetx(){cout<voidgety(){cout<};
voidprint(pointa){cout<<<main(){
pointa;
;
print(a);
}
print(pointa){cout<<<floatx,y;改为public:
floatx,y;或cour<<<44.#include<>
classf{
private:
int;
public:
fl(intb){x=a;y=b;}
voidprint(){cout<};
main(){
fa;
;
();
}
;f1()调用时实参与形参类型不一致
45.#include<>
main(){
intx=6;
constint*p=x;
cout<<*p<}
constint*p=x;变量给指针p赋值必须加上&
四、完成程序题(本大题共5小题.每小题4分.共20分)
46.完成下面程序.使其输出l0.并在退出运行时正确释放分配给指针的存储空间。
#include
usingnamespacestd;
voidmain()
{
int*a.*p;
a=newint(10);
p=_a_;
cout<<*p<deletep;或deletea;
}
47.#include
usingnamespacestd;
classbase
{
private:
intx;
public:
base(inta){x=a;}
intget(){returnx;}
voidshowbase(){cout<<"x="<};
classDerived:
publicbase
{private:
inty;
public:
Derived(intb):
base(a){y=b;}
voidshowderived()
{cout<<"x="<};
voidmain()
{
baseb(3);
Derivedd;
();
();
b=d;
();
baseb1=b;或base&b1=b;或baseb1(6);
();
base*pb=&bl;
pb—>showbase();
();
();
}
输出结果如下:
x=3
x==7
x=6
x=6
x=6
x==7
x=6
48.下面程序的运行结果如下:
B:
:
display()
C:
:
display()
在下划线处填上缺少的部分。
源程序如下:
#include
usingnamespacestd;
classB
{
public:
virtualvoiddisplay(){cout<<"B:
:
display()"<};
classC:
publicB
{
public:
voiddisplay(){cout<<"C:
:
display()"<};
voidfun(B*p)
{
p—>display();
}
voidmain()
{
Bb.*pb;
Cc;
pb=&b;
fun(pb);
pb=&c;
fun(pb);
}
49.下面程序的运行结果如下:
Thisisline1
Thisisline2
Thisisline3
在下划线处填上缺少的部分。
源程序如下:
#include
#includeusingnamespacestd;
voidmain()
{
fstreamfin,fout;
("".ios:
:
out);
if(!
())
return;
for(inti=0;i<3;i=i+1)
fout<<"Thisisline"<
();
("".ios:
:
in);
if(!
())
return;
charstr[100];
while(!
())
{
;
cout<}
();
}
50.在下划线处填上缺少的部分。
源程序如下:
#include
usingnamespacestd;
template或template
Tfun(Tx)
{
Ty;
y=x*x-T(5);
returny;
}
voidmain()
{
floata=2;
cout<}
五、程序分析题(本大题共4小题.每小题5分.共20分)
51.请写出文本文件中的内容
#include
#include
usingnamespacestd;
#include
voidmain()
{
ofstreammyFile1;
("");
cout<<"EnterthedatainChineseformat..25):
"<stringDate("1");
stringYear=;
intk=(".");
inti=("");
stringMonth=(k+;
stringDay=(i+;
stringNewDate=Day+""+Month+""+Year;
myFilel<<"originaldate:
"<myFile1<<"Converteddate:
"<();
}
originaldate:
2008,January1
Converteddate:
1January2008
52.给出下面程序的输出结果
#include
usingnamespacestd;
classSimple
{
int;
public:
Simple(){x=y=0;}
Simple(intj){x=i;y=j;}
voidcopy(Simple&s);
voidsetxy(intj){x=i;y=j;}
voidprint(){cout<<"x="<};
voidSimple:
:
copy(Simple&s)
{
x=;y=;
}
voidfunc(Simple&s2)
{
(30,40);
;
}
voidmain()
{
Simpleobj1.obj2;
(obj1);
func;
();
();
}
x=1,y=2
x=70,y=80
53.给出下面程序的输出结果
#include""
intmain()
{
inti=17;
while(i>=10)
if(--i%4==3)continue;
else
cout<<"i="<}
i=16i=14i=12i=10
54.给出下面程序的输出结果
#include
usingnamespacestd;
voidmain()
{
intnum=300;
int&ref=num;
cout<ref=ref-100;
cout<<""<num=num-50;
cout<<""<}
300200150
六、程序设计题(本大题共1小题.共10分)
55.定义堆栈类模板Stack(先进后出).栈的大小由使用者确定。
要求该类模板对外提供
如下二种基本操作:
(1)push入栈
(2)pop出栈.用数组来实现
#include
usingnamespacestd;
template
classStack{
Tx[size];
intcurrent;
public:
Stack(){current=0;}
....push(....);
....pop(....);
};
请写出两个函数的过程(如果需要形式参数.请给出形参类型和数量.以及返回值类型)
voidSatck:
:
push(Tt){
if(current==size){
cout<<“TheStackisfull!
”<else{x[current]=t;current++;}//新元素入栈并修改栈顶指针
}
TStack:
:
pop(){
if(current==0){
cout<<”ThereisnoobjectintheStack!
”<else{Ta=x[current-1];current--;returna;}//栈顶元素出栈并修改栈顶指针
}