1、一、给出一个有理数类,实现 有理数的加法运算。请按后列恳求 作答。
1.仔细 、残缺地阅读 次序 ,对应题号填写注释。注释的内容包括 两部分:1.本行的语句是什么;2.简述其功能 或特征 。比如 ,注释可以 如斯 写:“友员函数;重载加法运算符(+)。〞
〔每题1分,共10 分〕
#include
2、 int maxcommonFactor(int,int); //(1) void simplify( ); //(2) void DtoF(double,int&,int&); //(3) public: Rational(int n,int d=1); //(4) Rational(double x=0); //(5) ~Rational(); //(6)
3、 void plus(const Rational&); //(7) Rational operator + (const Rational&); //(例)公有成员函数;重载加法运算符(+)。 void showFraction( ); //(8) operator double( ); //(9) friend ostream &operator<< //(10) (ostream &output, Rational &t);
4、 }; 2. 对应题号把函数的定义 补偿 残缺。〔每题3分,共9 分〕 int Rational::maxcommonFactor(int a,int b) {if(a%b==0)return b; return (11) ;} void Rational::simplify( ) {int temp=maxcommonFactor(abs(numerator),abs(denominator)); if(temp==1)return; numerator/=temp;denominator/=temp; return;}
5、
void Rational::DtoF(double x,int & n,int & d)
{double s=fabs(x); d=1; while((s*d-int(s*d))>1e-15)d*=10;n=int(x*d);}
Rational::Rational(int n,int d)
{if(d==0) {cout<<"差错 ! 分母不克不迭 为0。有理数将置为0。"< 6、mplify(); }
Rational::Rational(double x)
{DtoF(x,numerator,denominator);simplify();}
Rational::~Rational( ){ }
void Rational::plus(const Rational& addend)
{numerator=addend.numerator*denominator+addend.denominator*numerator;
denominator*=addend.denominator;
simplify(); 7、}
Rational Rational::operator + (const Rational& t)
{Rational temp(0,1);
temp.numerator=numerator*t.denominator+denominator*t.numerator;
temp.denominator=denominator*t.denominator;
temp.simplify(); return temp;}
void Rational::showFraction( )
{if(numerator<0 && 8、 denominator<0 || numerator>=0 && denominator>0)
cout< 9、<<'/'< 10、ndl;
}
3. 按照题目 恳求 ,按对应题号作答。〔每题3分,共21分〕
·写出上述次序 的运行 结果。
(14)
·在上述次序 中,应用 成员函数重载加法运算符(+)。现假设 要改用友员函数重载加法运算符(+),下面给出了函数体,请写出呼应 的函数原型(声明 )跟 函数头。
函数原型 (15)
函数头 (16)
函数体 {Rational temp(0,1);
temp.simplify(); return temp; }
·在 11、上述次序 中,构造函数出现重载,我们 按其定义 的先后分不称为构造函数1跟 构造函数2。留心 到main函数中依次定义 了东西 a,b,c,d。请你分不写出这四个东西 的初始化各自调用 的是哪一个构造函数。
东西 a初始化: (17.a) ; 东西 b初始化: (17.b) ;
东西 c初始化: (17.c) ; 东西 d初始化: (17.d) ;
·在上述次序 中,请你补偿 一个复制构造函数的定义 ,恳求 用内联函数实现 。
(18)
复制构造函数跟 重载赋值运算符函数虽然根本上 实现 数据成员的复 12、制,但实行 机会 差异 。复制构造函数素日 用于(19.a) 跟 转达 东西 参数,当函数前去 类典范 时,也要通过复制构造函数树破 临时 东西 ;重载赋值运算符函数用于(19.b) 。
·假设 在上述次序 的基础上,于main函数末了 处添加 一行:
for(int i=0;i<=1;i++)c.plus(c+d); cout< 13、include 14、
void show( ){cout< 15、按恳求 ,类B构造函数定义 可以 改写成:
(23)
·偶尔 需要 复制A类东西 的数据去创破 B类东西 ,请用内联函数的方法 写出类B的重载构造函数:
(24)
·假设 在上述main函数的末了 添加 一句:cout< 16、 〔每题3分,共18分〕
以下次序 中,类B1,B2虚承袭类A,类C多承袭B1,B2。按题目 恳求 作答。留心 A为虚基类,树破 直截了当 派生类东西 时,只需一个a东西 的数据成员版本。
#include 17、virtual public A //矩形面积
{ public :
B1(double px=2, double py=2):A(px,py){ }
void show(){cout<<"[B1]=>"< 18、z< 19、>show( );
p=&b1; p->show( );
p=&b2; p->show( );
p=&c; p->show( );
}
·写出上述次序 的运行 结果。
(27)
·在类A的show函数之前加上关键 字virtual,再写出上述次序 的运行 结果。
(28)
·在(28)题基础上,于原main 函数的末了 添加 ((B2)c).show( ); 结果将多表示 一行:
(29)
·把类A的show函数改写成纯虚函数。
(30)
20、
·假设 类A的show函数改写成纯虚函数,原本 的main函数不克不迭 畸形 运行 ,什么缘故 ?请庞杂 说明因由 。
(31)
·类A的show函数改写成纯虚函数后,请你对原本 的main函数作庞杂 的删改 ,使其可以 输出派生类的数据。
(32)
三、给出一些关于 应用 模板的次序 段,按恳求 作答。
1.以下次序 用函数模板实现 两个数据的交换 ,请把有关的语句填充 残缺。
〔每题3分,共9分〕
#include 21、35) }
void main()
{ int j=1,k=3;
cout<<"int 数据典范 :\n"< 22、 cout<
#include 23、n(int x,int y)
{return (38) ;}
void main( )
{ int a[size]={10,3,17,6,15,8,13,34,25,2};
vector 24、t(V.begin( ),V.end( ),down); // 对向量按落序排序
cout<<"输出落序摆设 后的数组: \n" ;
display(V,size);
}
四、给出一个输出输出流把持 的次序 段,请把有关的语句填充 残缺。
〔每题3分,共6分〕
#include






