1、国家二级 C+机试(操作题)模拟试卷 270及答案与解析 一、基本操作题 1 使用 VC6打开考生文件夹下的源程序文件 modi1 cpp,但该程序运行时有错,请改正程序中的错误,使程序输出的结果为: Number=8 注意:错误的语句在 *error*的下面,修改该语句即可。 #include iostream.h class CMyClass public: *error* void&Get() return&Number; void Set(int m) Number=m; void display() cout “Number=“ Number endl; private: int N
2、umber; ; voidmain() int*p; *error* *error* p=t Get(), *p=8; t display()j 二、简单应用题 2 使用 VC6打开考生文件夹下的源程序文件 modi2 cpp。请完成以下函数: int factorial(int n):求出 n的阶乘,必须使用递归调用。 如果 n小于 1则返回 0。 注意:不能修改函数的其他部分。 #include iostream h #include ctype h int factorial(int n) void main() cout factorial(1) endl; cout factoria
3、l(5) endl; cout factorial(0) endl; return; 三、综合应用题 3 使用 VC6打开考生文件夹下的源程序文件 modi3 cpp,通过把类 Distance定义为类 Point的友元类,来实现计算两点之间距离的功能。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。 (1)把类 CDistance定义为类 CPoint的友元类。请在注释 *1*之后添加适当的语句。 (2)定义类 CPoint的构造函数,完成给私有数据成员 x和 y的赋值,并且两个参数的缺省值都为 0。请在注释 *2*之后添加适当的语句。 (3)完成类 CDistance的成员函
4、数 length(Point&pPoint, Point&qPoint)的定义,并在其中计算点 p、 q之间的距离,并且返回结果。假设两点之间的距离distance=sqrt(pPoint x-qPoint x)*(pPoint x-qPoint x)+(pPoint y-qPoint y)*(pPoint y-qPoint y)。请在注释 *3*之后添加适当的语句。 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。 #include iostream #include cmath using namespace std; class CPoint public
5、: *1* 定义类 Point的构造函数 *2* void display()cout “x=“ x endl; cout “y=“ y endl; private: float x, y; ; class CDiStance public: float length(CPoint&p, CPoint &q); ; float CDistance: length(CPoint&pPoint, CPoint&qPoint) *3* int main() CPoint mPoint(10, 10), nPoint(40, 50); mPoint display(); nPoint display(
6、); CDistance len; cout len length(mPoint, nPoint) endl; return0; 国家二级 C+机试(操作题)模拟试卷 270答案与解析 一、基本操作题 1 【正确答案】 (1)void* Get() (2)添加语句: CMyClass t: (3)p=(int*) t Get(); 【试题解析】 (1)Get()的返回的是 “return&Number; ”,即返回 Number的地址,主函数中 p为整型指针,但是 “p=t Get(); ”有错误,因为 Get()函数返回的不是整型指针,而应该是空指针 (void),空指针可强制类型转换成其他
7、类型的指针,第 1个标识下应改为 “void* Get()”。 (2)由于 Get()函数返回空指针 (void),要使 p指向 Get()函数的返回值,必须做强制类型转化,即第 3个标识下应改为 “p=(int*)t Get(); ”。 (3)变量 t可以使用 Get()函数,说明 t为 CMyClass类对象。即第 2个标识下应添加对象定义,故第 2个标识 F添加 “CMyClass t: ”。 二、简单应用题 2 【正确答案】 if (n 1) return0; else if(n=1) return1; elsse return n*factorial(n-1); 【试题解析】 (1)
8、先考虑最简单的情况, n为 1(或 小于 1)时返回值应该为 1,即factorial(1)=1,这是递归结束条件,如果 n大于 1则递归调用自己。 (2)n 1时,此时递归函数调用自己,即 factorial(n)=n*factorial(n-1),此时的函数的返同值是 n*factorial(n-1),如此来实现递归调用。 三、综合应用题 3 【正确答案】 (1)添加语句: friend class CDistance; (2)添加语句: CPoint(float a=0, float b=0)x=a; y=b; (3)添加语句: return sqrt(pPoint x-qPoint x
9、)*(pPoint x-qPoint x)+(pPoint y-qPoint y)*(pPoint y-qPoint y); 【试题解析】 (1)第 1个标识下补充定义类 CDistance为类 CPoint的友元类,声明友元类的格式为: friend类名:,故第 1个标识下应添加 “friend class CDistance; ”。 (2)类 CPoint的构造函数完成给私有数据成员 x和 y的初始化,两个参数的缺省值都为 0,因此参数含有默认值 0,故第 2个标识下应添加 “CPoint(float a=0 float b=0)x=a: y=b; ”。 (3)类 CDistance的成员函数 length(CPoint&pPoint, CPoint&qPoint)返回点 p、 q之间的距离,可由公式 distance=sqrt(pPoint x-qPoint x)*(pPoint x-qPoint x)+(pPoint yqPoint y)*(pPoint y-qPoint y)计算求得,第 3个标识下应添加 “return sqrt(pPoint x-qPoint x)*(pPoint x-qPoint x)+(pPoint y-qPoint y)*(pPoint y-qPoint y); ”。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1