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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C+机试(操作题)模拟试卷 211及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 proj1下的工程 proj1。其中有线段类 Line的定义。程序中位于每个 “ ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应该是: End point 1=(1, 8), End point 2=(5, 2), length=7 211 1。 注意:只修改每个 “ ERROR*found*”下的那一行,不要改动程序中 的其他内容。 1 #include 2 #include 3 using namespace std; 4 cla

2、ss Line; 5 double length(Line); 6 class Line 线段类 7 double x1 , y,1;线段端点 1 8 double x2, y2;线段端点 2 9 public: 10 ERROR *found* 11 Line(double x1, double y1, doublex2, double y2)const 12 this-x1: x1; 13 this-y1=y1; 14 this-x2=x2; 15 this-y2=y2; 16 17 double getXl()constreturn x1l; 18 double getYl()const

3、return y1; 19 double getX2()const return x2 20 double getY2()const return y2; 21 void show()const 22 cout “End point 1=(“ 2 include 3 using namespace std; 4 class Graphics 图形类 5 6 public: 7 Graphics(int e): edges(e)( 8 *found* 9 _; 10 protected: 11 int edges; 12 ; 13 class Squares: public Graphics正方

4、形类 14 15 public: 16 Squares(int x): Graphics(x) 17 void Draw(); 18 ; 19 void Squares: Draw() 20 21 int i, j; 22 if(edges0) 25 26 for(i=0; i0) 47 48 for(i=0; ie; 66 Graphics*objs2; 67 objs0=new Diamonds(e); 68 objs1=new Squares(e); 69 for(int i=0; iDraw(); 71 delete objs0; 72 delete objs1; 73 return

5、0; 74 三、综合应用题 3 请使用【答题】菜单命令或直接用 VC6打开考生文件夹下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的整型数组。 ValArray类的复制构造函数应实现对象的深层复制。请编写 ValArray类的复制构造函数。在 main函数中给出了一组测试数据,此种隋况下程序的输出应该是: ValArray vl=1, 2, 3, 4, 5 ValArray v2: 1, 2, 3, 4, 5 要求: 补充编制的内容写在 “ *333*”与 “ *666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out dat中。输出函

6、数 writeToFile已经编译为 boj文件,并且在本程序中调用。 1 ValArray h 2 #include 3 using namespace std; 4 5 class ValArray 6 int*v; 7 int size; 8 public: 9 ValArray(const int*p, int n): size(n) 10 11 v=new intsize; 12 for(int i: 0; i0; i-) 【试题解析】 (1)由于 Graphic的子类都使用了 Draw()成员函数,并且都有自己各自不同的实现,很容易发现类中成员多态的特性,类的多态是使用虚函数来实现

7、的。 (2)Diamonds的成员函数 Draw()中使用了 edges。但是类 Diamonds中没有该成员,而 Graphic中有此成员,可知该类公有继承了 Graphic。 (3)根据图形的变化可知第一行 1个 *,第二行 3个 *,第三行 5个 *,增长的规律是 2*i+l,因而可以很容易得出结果。 (4)菱形的下半部分是由 5个 *开始递减的,即从最大边递减,直到为 0,可 以得出答案。 三、综合应用题 3 【正确答案】 1 size=other size; 2 v=new intsize; 3 for(int i =0; i size; i+) 4 setArray(i, other vi); 【试题解析】 主要考查考生对复制构造函数的掌握, ValArray类的复制构造函数应实现对象的深层复制。由 ValArray类的构造函数: 1 ValArray(const int* p, int n) : size(n) 2 3 v=new intsize;给 v分配大小为 size的空间 4 for (int i =0; i size; i+)遍历 p 5 vi=pi;把 pi赋值给 vi 6 可知类中 v是动态数组, size表示数组长度,因此要先给 v分配空间为 size,再逐个元素复制以达到对象的深层复制。

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