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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】国家二级C++机试(操作题)-试卷80及答案解析.doc

1、国家二级 C+机试(操作题)-试卷 80 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6 打开考生文件夹下的源程序文件 modi1cpp,但该程序运行时有错,请改正程序中的错误,使程序输出的结果为:m=-10n=-10p=0q=-10z=A 注意:错误的语句在*error*的下面,修改该语句即可。#includeiostreamhvoid main()double m=10;float n=10;bool p=1;int q=10;char z=a;m=-m;*error*n=n;*error*p=-p;*error*q=q;z=

2、z-32;cout“m=“mendl;cout“n=“nendl;cout“p=“pendl;cout“q=“qendl;cout“z=“zendl;return;(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。阅读下列函数说明和代码,补充空出的代码。程序的功能是寻找 1500 以内的亲和数并显示出来,函数 amicableNum(int m,int n)判定两个数是否是亲和数。亲和数的定义为:两个数 m 和 n,如果 n 的所有因子之和(因子除掉自身)等于 m,且 m 的所有因子等于 n,则 m、n 是互为亲和

3、数。注意:不能修改程序的其他部分,只能补充 amicableNum(int m,int n)函数。#includeiostreamhint amicableNum(int n)int sum=0;for(int i=1;in;i+)if(ni=0)sum+=i;return sum;bool amicableNum(int m,int n)void main()cout“1500 以内的亲和数有:“endl;for(int i=1;i500;i+)for(int j=i+1;j500;j+)if(i!=j)if(amicableNum(i,j)=1)couti jendl;return;(分数

4、:2.00)_三、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生文件夹下的源程序文件 modi3cpp,其中定义了用于表示矩形的 CRect 类,但类CRect 的定义并不完整。请按要求完成下列操作,将类 CRect 的定义补充完成。(1)定义私有数据成员lefiPoint、topPoint、rightPoint、bottomPoint,分别用于表示矩形左上角及右下角的点的坐标,它们都是 double 型的数据。请在注释*1*之后添加适当的语句。(2)完成默认构造函数CRect 的定义,指定缺省实参为 0,都是 double 型的数据。请在注释*2*之后添加适当的语句。(3

5、)定义函数体为空的析构函数。请在注释*3*之后添加适当的语句。(4)在 main()函数中定义 CRect 类的实例 rect2,并把 rectl 的值赋给 rect2。请在注释*4*之后添加适当的语句。注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。#includeiostreamhclass CRectprivate:*1*public:*2*3*void SetPoints(double,double,double,double);void SetLeftPoint(double m)leftPoint=m;void SetRightpoint(double m)rightP

6、oint=m;void SetToppoint(double m)topPoint=m;void SetBottomPoint(doublem)bottomPoint=m;void Display();CRect:CRect(double1,double t,double r,double b)leftPoint=1;topPoint=t;rightPoint=r;bottomPoint=b;void CRect:SetPoints(double1,double t,double r,double b)leftPoint=1;topPoint=t;rightPoint=r;bottomPoin

7、t=b;void CRect:Display()cout“left-top point is(“leftPoint“,“topPoint“)“n;cout“right-bottom point is(“rightPoint“,“bottomPoint(“)“n;void main()CRect rect0;rect0Display();rect0SetPoints(20,206,30,40);rect0Display();CRect rectl(0,0,150,150);rectlSetTopPoint(105);rectlSetLeftPoint(105);*4*rect2Display()

8、;(分数:2.00)_国家二级 C+机试(操作题)-试卷 80 答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6 打开考生文件夹下的源程序文件 modi1cpp,但该程序运行时有错,请改正程序中的错误,使程序输出的结果为:m=-10n=-10p=0q=-10z=A 注意:错误的语句在*error*的下面,修改该语句即可。#includeiostreamhvoid main()double m=10;float n=10;bool p=1;int q=10;char z=a;m=-m;*error*n=n;*error*p=-p;*er

9、ror*q=q;z=z-32;cout“m=“mendl;cout“n=“nendl;cout“p=“pendl;cout“q=“qendl;cout“z=“zendl;return;(分数:2.00)_正确答案:(正确答案:(1)n=-n; (2)p=!p; (3)q=-q;)解析:解析:(1)程序中定义了多个变量,并做了一些基本的运算处理。 (2)由题目要求的运行结果可知,第 1 个标识下和第 3 个标识下是对变量 n 和 q 取反,求。个正数的相反数可以通过算数运算符“-”得到,第 1 个标识下和第 3 个标识下应分别改为“n=-n;”和“q=-q;”,即只需要通过负号运算就可以实现。

10、(3)从题目要求输出的结果来分析,第 2 标识下是对逻辑变量 p 取反,对一个逻辑变量求反应该用取反运算符“!”,第 2 个标识下应改为“p=!p”。二、简单应用题(总题数:1,分数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。阅读下列函数说明和代码,补充空出的代码。程序的功能是寻找 1500 以内的亲和数并显示出来,函数 amicableNum(int m,int n)判定两个数是否是亲和数。亲和数的定义为:两个数 m 和 n,如果 n 的所有因子之和(因子除掉自身)等于 m,且 m 的所有因子等于 n,则 m、n 是互为亲和数。注意:不能修改程序的其他部分,

11、只能补充 amicableNum(int m,int n)函数。#includeiostreamhint amicableNum(int n)int sum=0;for(int i=1;in;i+)if(ni=0)sum+=i;return sum;bool amicableNum(int m,int n)void main()cout“1500 以内的亲和数有:“endl;for(int i=1;i500;i+)for(int j=i+1;j500;j+)if(i!=j)if(amicableNum(i,j)=1)couti jendl;return;(分数:2.00)_正确答案:(正确答案

12、:if(amicableNUm(m)=n &amicableNum(n)=m) return1; return0;)解析:解析:(1)程序中定义了两个 amicableNum()函数,由于参数个数不同重载了 amicableNum()函数,函数 amicableNum(int n)返回 n 的因子和,而函数 amicableNum(int m,int n)则是判断 m 和 n 是不是亲和数,两个函数功能并不相同。 (2)在 amicableNum(int m,int n)函数中,可调用 amicableNum(int n)函数求 m 和 n 的因子和,然后比较两个因子和,如果两个因子和相同则返

13、回真,否则返回假。三、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生文件夹下的源程序文件 modi3cpp,其中定义了用于表示矩形的 CRect 类,但类CRect 的定义并不完整。请按要求完成下列操作,将类 CRect 的定义补充完成。(1)定义私有数据成员lefiPoint、topPoint、rightPoint、bottomPoint,分别用于表示矩形左上角及右下角的点的坐标,它们都是 double 型的数据。请在注释*1*之后添加适当的语句。(2)完成默认构造函数CRect 的定义,指定缺省实参为 0,都是 double 型的数据。请在注释*2*之后添加适当的语句。

14、(3)定义函数体为空的析构函数。请在注释*3*之后添加适当的语句。(4)在 main()函数中定义 CRect 类的实例 rect2,并把 rectl 的值赋给 rect2。请在注释*4*之后添加适当的语句。注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。#includeiostreamhclass CRectprivate:*1*public:*2*3*void SetPoints(double,double,double,double);void SetLeftPoint(double m)leftPoint=m;void SetRightpoint(double m)righ

15、tPoint=m;void SetToppoint(double m)topPoint=m;void SetBottomPoint(doublem)bottomPoint=m;void Display();CRect:CRect(double1,double t,double r,double b)leftPoint=1;topPoint=t;rightPoint=r;bottomPoint=b;void CRect:SetPoints(double1,double t,double r,double b)leftPoint=1;topPoint=t;rightPoint=r;bottomPo

16、int=b;void CRect:Display()cout“left-top point is(“leftPoint“,“topPoint“)“n;cout“right-bottom point is(“rightPoint“,“bottomPoint(“)“n;void main()CRect rect0;rect0Display();rect0SetPoints(20,206,30,40);rect0Display();CRect rectl(0,0,150,150);rectlSetTopPoint(105);rectlSetLeftPoint(105);*4*rect2Display

17、();(分数:2.00)_正确答案:(正确答案:(1)添加语句:double leftPoint,topPoint,rightpoint,bottomPoint; (2)添加语句:CRect(double leftPoint=0,double topPoint=0,double rightPoint=0,double bottomPoint=0); (3)添加语句:CRect(); (4)添加语句:CRect rect2(rect1);)解析:解析:(1)第 1 个标识下完成私有数据成员 lefiPoint、topPoint、rightPoint、bottomPoint 的定义,均为 doub

18、le 型的变量,故第 1 个标识下应添加“double leftPoint,topPoint,rightPoint,bottomPoint;”。 (2)构造函数完成成员变量的初始化,类 CRect的默认构造函数并初始化 double 型私有数据成员 leftPoint、topPoint、rightPoint、bottomPoint 为0,故第 2 个标识下应添加“CRect(double lettPoint=0,doubletopPoint=0,double rightPoint=0,double bottomPoint=0);”。 (3)析构函数名和类名一致,并在前面加“”以和构造函数区别,该析构函数体为空,故第 3 个标识下应添加“CRect();”,虽然该函数体为空,但是“”必须保留。 (4)主函数中类 CRect 的对象 rect2 是通过复制构造函数将 rect1 的值赋值给它实现初始化的,而 rect1 的初始化直接调用自定义构造函数,第 4 个标识下应添加“CRectrect2(rect1);”。

copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1