欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:1331844       资源大小:46KB        全文页数:5页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    1、国家二级 C+机试(操作题)模拟试卷 346及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.请使用 VC6或使用【答题】菜单打开考生文件夹 proj1下的工程 proj1,该工程中包含程序文件maincpp,其中有类 Door(“门”)和主函数 main的定义。程序中位于每个“ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应为: 打开503号门门是锁着的,打不开。 打开 503号门的锁锁开了。 打开 503号门门打开了。 打开 503号门门是开着的,无须再开门。 锁上 503号门先关门门锁上了。 注意:只修改每

    2、个“ERROR*found*”下的那一行,不要改动程序中的其他内容。#includeiostreamusing namespace std;class Door int num; 门号 bool closed; true 表示门关着 bool locked; true 表示门锁着 public: Door(int num)ERROR*found* num=thiS-num; closed=locked=true; bool isClosed()const returnclosed;门关着时返回 true,否则返回 false bool isOpened()constreturn!closed;

    3、)门开着时返回 true,否则返回 false bool iSLocked()const returnlocked;)门锁着时返回 true,否则返回 false bool isUnlocked()conStreturn ! locked;)门未锁时返回 true,否则返回 false void open() 开门 coutend1”打开”num”号门”; ERROR*found* if(closed) cout”门是开着的,无须再开门。”; else if(locked) cout”门是锁着的,打不开。”; else Closed=false; cout“门打开了。”; void close

    4、() 关门 coutendl”关上”num”号门”; if(closed) cout”门是关着的,无须再关门。”; else closed=true; cout“门关上了。”; ERROR*found* void lock()const 锁门 coutendl“锁上”num”号门”; if(locked) cout“门是锁着的,无须再锁门。”; eise if(!closed) cout”先关门”; closed=true; locked=true; cout”门锁上了。”; void unlock() 开锁 coutendl”开”num”号门的锁”; if(!locked) cout“门没有

    5、上锁,无须再开锁。”; eise locked=false;cout”锁开了。”; ; int main() Door door(503); dooropen(); doorunlock(); dooropen(); dooropen(); doorlock(), return 0; (分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.请使用 VC6或使用【答题】菜单打开考生文件夹 pmj2下的工程 pmj2。其中有类 Point(“点”)、lteetangle(“矩形”)和 Circle(“圆”)的定义。在程序所使用的平面坐标系统中,x 轴的正方向是水平向右的,y 轴的正方向

    6、是竖直向下的。请在横线处填写适当的代码并删除横线,以实现上述类定义。此程序的正确输出结果应该是: 一一圆形一一一一 圆心=(3,2) 半径=1 面积=314159 一一外切矩形一一 左上角=(2,1) 右下角=(4,3) 面积 =4 注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。#includeiostream#includecmathusing namespaoe std;平面坐标中的点本题坐标系统中,x 轴的正方向水平向右,y 轴的正方向竖直向下。class Point:public: Point(double X=00,double y=

    7、00):x 一(x),y 一(y) double getX()constreturn x_;) double getY()constreturn y_;) void setX(double x)x_=x;) void setY(double y)y_=y;)private: double x_; x 坐标 double y_;y 坐标;/矩形 class Rectanglepublic: Rectangle(Point P,int w,int h) :point(p),width(w),height(h) double area()const矩形面积 return width*height;

    8、Point topLeft()const左上角顶点 return point; Point bottomRight()const右下角顶点(注:Y 轴正方向竖直向下) *found*return Point(_);private: Point point;左上角顶点 double width;水平边长度 double height;垂直边长度 ; /圆形 class Circle public: Circle(Point P,double r):center(p),radius(r) RectangleboundingBox()const;外切矩形 double area()const圆形面积

    9、 *found* return PI*_; public: static const double PI;圆周率 private: Point center; 圆心 double radius; 半径 ; const double Circle:PI=314159; Rectangle Circle: boundingBOx ()const *found*Point pt(_);int w,h; *found* W=h=_; return Rectangle(pt,W,h); int main() Point P(3,2); Circle c(p,1); cout”一一圆形一一一一一nn; c

    10、out”圆心=(”PgetX() ,PgetY() ”)n”; cout”半径=”1endl; cout“面积=“carea() endlendl; Rectangle bb=CboundingBox(); Point t1=bbtopLeft(); Point br=bbbottomRight(); cout”一一外切矩形一一一一一n”; cout”左上角=(”t1getX() ,t1getY() ”)n”; cout”右下角=(”brgetX() ,brgetY() ”)n”; cout”面积=”bbarea() endl; return 0; (分数:2.00)_三、综合应用题(总题数:

    11、1,分数:2.00)3.请使用 VC6或使用【答题】菜单打开考生文件夹 pros3下的工程 prog3,其中包含了类P0lynomial(“多项式”)的定义。 形如 5x 4 +34x 2 一 7x+2的代数式称为多项式,其中的 5为 4次项系数,34 为 2次项系数,一 7为 1次项系数,2 为 0次项(常数项)系数。此例缺 3次项,意味着 3次项系数为 0,即省略了 0x 3 。在 Polynomial中,多项式的各个系数存储在一个名为 coef的数组中。例如,对于上面的多项式,保存在 coef0、coef1coef4中的系数依次为:20、一70、34、00,50,也即对于 i次项,其系数

    12、就保存在 coefi中。成员函数 getValue计算多项式的值,多项式中 x的值是由参数指定的。 请补充完成文件 Polynomialcpp 中成员函数 getValue的定义。此程序的正确输出结果应为: Value of pl when x=20:598 Value of p2 when x=30:2268 注意:只在函数 getValue的“*333*”和“*666*”之间填入若干语句,不要改动程序中的其他内容。 Polynomiach #include using namespace std; class,Polynomial “多项式”类 public: Polynomial(dou

    13、ble coef,int num):coef(new doublenum),num of terms(num) for(int i=0;icoefi=coefi; 一 Polynomial()deletecoef; 返回指定次数项的系数 double getCoefficient(int power) constreturn coefpower; 返回在 X等于指定值时多项式的值 double getValue(double x)const; private: 系数数组,coef0为 0次项(常数项)系数,coef1为 1次项系数,coef2为 2次项(平方项)系数,余类推。 double*c

    14、ogf; int hum_of_terms; ; void writeToFile(const char*path); /Polymomialcpp #include”Polynomialh” double Polynomial:getValue(double X)const 多项式的值 value为各次项的累加和 double value=coef0; /*333* *666* return value; maincpp #include”Polynomialh” int main() double pl=:50,34,-40,80), p2=00,一 54,00,30,20); Polyn

    15、omial polyl(pl,sizeof(p1) sizeof(double),poly2(p2,sizeof (p2)sizeof(double); coutnum=nun; (2)if(!closed) (3)void lock()解析:解析:(1)主要考查考生对 this指针的掌握,在构造函数中 this指针指向的是当前类,因此要给num赋值使用语句 this一num=num;完成。 (2)主要考查考生对 if语句的掌握,先看类的私有成员中关于 closed的定义:bool closed;true 表示门关着。再看下一条语句:cout”门是开着的,无须再开门。”;。即满足条件时就会输出

    16、:门是开着的,无须再开门。因此 if括号内应该是!closed。 (3)主要考查考生对 const函数的掌握,lock 函数体中存在语句 locked=true,即有参数发生改变,因此不能用 const。二、简单应用题(总题数:1,分数:2.00)2.请使用 VC6或使用【答题】菜单打开考生文件夹 pmj2下的工程 pmj2。其中有类 Point(“点”)、lteetangle(“矩形”)和 Circle(“圆”)的定义。在程序所使用的平面坐标系统中,x 轴的正方向是水平向右的,y 轴的正方向是竖直向下的。请在横线处填写适当的代码并删除横线,以实现上述类定义。此程序的正确输出结果应该是: 一一

    17、圆形一一一一 圆心=(3,2) 半径=1 面积=314159 一一外切矩形一一 左上角=(2,1) 右下角=(4,3) 面积 =4 注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。#includeiostream#includecmathusing namespaoe std;平面坐标中的点本题坐标系统中,x 轴的正方向水平向右,y 轴的正方向竖直向下。class Point:public: Point(double X=00,double y=00):x 一(x),y 一(y) double getX()constreturn x_;) dou

    18、ble getY()constreturn y_;) void setX(double x)x_=x;) void setY(double y)y_=y;)private: double x_; x 坐标 double y_;y 坐标;/矩形 class Rectanglepublic: Rectangle(Point P,int w,int h) :point(p),width(w),height(h) double area()const矩形面积 return width*height; Point topLeft()const左上角顶点 return point; Point botto

    19、mRight()const右下角顶点(注:Y 轴正方向竖直向下) *found*return Point(_);private: Point point;左上角顶点 double width;水平边长度 double height;垂直边长度 ; /圆形 class Circle public: Circle(Point P,double r):center(p),radius(r) RectangleboundingBox()const;外切矩形 double area()const圆形面积 *found* return PI*_; public: static const double P

    20、I;圆周率 private: Point center; 圆心 double radius; 半径 ; const double Circle:PI=314159; Rectangle Circle: boundingBOx ()const *found*Point pt(_);int w,h; *found* W=h=_; return Rectangle(pt,W,h); int main() Point P(3,2); Circle c(p,1); cout”一一圆形一一一一一nn; cout”圆心=(”PgetX() ,PgetY() ”)n”; cout”半径=”1endl; cou

    21、t“面积=“carea() endlendl; Rectangle bb=CboundingBox(); Point t1=bbtopLeft(); Point br=bbbottomRight(); cout”一一外切矩形一一一一一n”; cout”左上角=(”t1getX() ,t1getY() ”)n”; cout”右下角=(”brgetX() ,brgetY() ”)n”; cout”面积=”bbarea() endl; return 0; (分数:2.00)_正确答案:(正确答案:(1)pointgetX()+width,pointgetY()+height (2)radius*ra

    22、dius (3)centergetX()一 radius,centergetY()一 radius (4)2*radius)解析:解析:(1)主要考查考生对成员函数的掌握,程序要求返回右下角顶点,该点的 x坐标为左上角顶点的 x坐标加上 width,该点的 y坐标为左上角顶点 y坐标加上 height,即 return Point(pointgetX()+width,pointgetY()+height);。 (2)主要考查考生对成员函数的掌握,程序要求计算圆形面积,也就是返回圆面积,即 return PI*radius*radius;。 (3)主要考查考生对成员函数的掌握,首先看函数声明:R

    23、ectangle Circle:boundingBox()const,可知该函数要返回的是一个 Rectangle类型,即要返回的是圆的外切矩形。再看 Rectangle类的构造函数 Rectangle(Point P,int W,int h),由此可知,空格处要定义的点 pt为左上角点,即 Point pt(centergetX()一 radius,centergetY()一 radius);。 (4)由函数声明和 Rectangle类的构造函数可知,W 和 h应该为直径,即 W=h=2*radius;。三、综合应用题(总题数:1,分数:2.00)3.请使用 VC6或使用【答题】菜单打开考生

    24、文件夹 pros3下的工程 prog3,其中包含了类P0lynomial(“多项式”)的定义。 形如 5x 4 +34x 2 一 7x+2的代数式称为多项式,其中的 5为 4次项系数,34 为 2次项系数,一 7为 1次项系数,2 为 0次项(常数项)系数。此例缺 3次项,意味着 3次项系数为 0,即省略了 0x 3 。在 Polynomial中,多项式的各个系数存储在一个名为 coef的数组中。例如,对于上面的多项式,保存在 coef0、coef1coef4中的系数依次为:20、一70、34、00,50,也即对于 i次项,其系数就保存在 coefi中。成员函数 getValue计算多项式的值

    25、,多项式中 x的值是由参数指定的。 请补充完成文件 Polynomialcpp 中成员函数 getValue的定义。此程序的正确输出结果应为: Value of pl when x=20:598 Value of p2 when x=30:2268 注意:只在函数 getValue的“*333*”和“*666*”之间填入若干语句,不要改动程序中的其他内容。 Polynomiach #include using namespace std; class,Polynomial “多项式”类 public: Polynomial(double coef,int num):coef(new doubl

    26、enum),num of terms(num) for(int i=0;icoefi=coefi; 一 Polynomial()deletecoef; 返回指定次数项的系数 double getCoefficient(int power) constreturn coefpower; 返回在 X等于指定值时多项式的值 double getValue(double x)const; private: 系数数组,coef0为 0次项(常数项)系数,coef1为 1次项系数,coef2为 2次项(平方项)系数,余类推。 double*cogf; int hum_of_terms; ; void wr

    27、iteToFile(const char*path); /Polymomialcpp #include”Polynomialh” double Polynomial:getValue(double X)const 多项式的值 value为各次项的累加和 double value=coef0; /*333* *666* return value; maincpp #include”Polynomialh” int main() double pl=:50,34,-40,80), p2=00,一 54,00,30,20); Polynomial polyl(pl,sizeof(p1) sizeof

    28、(double),poly2(p2,sizeof (p2)sizeof(double); cout(分数:2.00)_正确答案:(正确答案:for(int i=1;inum of terms;i+ +) 从 i=1开始遍历数组 coef的所有项 int j=i一 1; 把 i一 1赋值给 j,保证从零次方开始 double X value=X; 把 X赋给 X value while(j0) 当 j大于零时,做相乘操作,即完成该项的乘方动作 x_value*=x; j-; value+=coefi=*X value; 把 i项的乘方结果乘以该项系数后加进 value中 )解析:解析:题目要求成员函数 getVahe计算多项式的值,多项式中 x的值由参数指定,多项式的值value为各次项的累加和。由类的定义可知数组 coef中存储的是各次项的系数,这里使用 for循环来完成题目要求,当次项为 0时,value=coef0。当次项为 1时,value=coef1* x+coef0。依次类推直到 X的最高次数。


    注意事项

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开