ImageVerifierCode 换一换
格式:DOC , 页数:5 ,大小:30.50KB ,
资源ID:497344      下载积分:2000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
注意:如需开发票,请勿充值!
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-497344.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文([计算机类试卷]国家二级C++机试(操作题)模拟试卷270及答案与解析.doc)为本站会员(赵齐羽)主动上传,麦多课文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知麦多课文库(发送邮件至master@mydoc123.com或直接QQ联系客服),我们立即给予删除!

[计算机类试卷]国家二级C++机试(操作题)模拟试卷270及答案与解析.doc

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