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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C+机试(操作题)模拟试卷 288及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 proj1下的工程 proj1,其中有枚举 DOGCOLOR、狗类 Dog和主函数 main的定义。程序中位于每个 “ERROR *found*”下的语句行有错误,请加以改正。改正后程序的输出结果应该是: There is a white dog named Hobo There is a black dog named Haha There is a motley dog named Hihi 注意:只修改每个 “ ERROR *found*”下的那一行,不要改动程序

2、中的其他内容。 #include iostream using namespace std; 狗的颜色:黑、白、黄、褐、花、其他 enum DOGCOLORBLACK, WHITE, YELLOW, BROWM, PIEBALD, OTHER); class Dog狗类 DOGCOLOR color; char name20; static: int count; public: Dog(char name, DOGCOLORcolor) strcpy(this name, name); ERROR *found* strcpy(this color, color); DOGCOLOR get

3、Color()const return color; ERROR *found* const char* getName()const return *name; const char* getColorString()const switch(color) case BLACK: return“black“; case WHTTE: Eeturn“white“; case YELLOW: return“yellow“; case BROWN: return“brown“; case PIEBALD: return“piebald“; return“motley“; void show()co

4、nst cout “There is a“ getColorString() “dog named“ name end1; , int main() ERROR *found* Dog dog1(“Hoho“, WHITE), dog2(“Haha“, BLACK); dog3(“Hihi“, OTHER); dog1 show(); dog2 show(); dog3 show(); return 0; 二、简单应用题 2 请使用 VC6或使用【答题】菜单打开考生文件夹 proj2下的工程 proj2,该工程中包含一个程序文件 main cpp,其中有坐标点类 point、线段类 Line和

5、三角形类Triangle的定义,还有 main函数的定义。程序中两点间距离的计算是按公式 d现的,三角形面积的计算是按公式 f了可实现的,其中 s 。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为: Side 1: 9 43398 Side 2: 5 Side 3: 8 area: 20 注意:只在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动 “ *found*”#include iostream #include cmath using namespace std; class Point 坐标点类public: const d

6、ouble x, y; Point(double x 0 0, doubley 0 0): x(x), y(y) *found* double distanceTo(_)const到指定点的距离 return sqrt(x P x)*(x-p x) (y P y)*(y P y); ; class Line线段类 public: const Point p1, p2;线段的两个端点 *found* Line(Point p1, Point p2): _ double length()constreturnp1 distanceTo(p2); )线段的长度 ; class Triangle三形类

7、 public: const Point p1,rp2,p3;三角形的三个顶点*found* Triangle(_): p1(p1), p2(p2), p3(p3)double lengthl()const边 p1, p2的长度 return Line(p1, p2) length (); double length2()const边 p2, p3的长度 return Line(p2, p3) length (); double length3()const边 p3, p1的长度 return Line(p3, p1) length (); double area()const三角形面积 *f

8、ound* double s _; return sqrt(s * (s length1() * (s length2() * (slength3(); ; int main() Triangle r(Point(0 0, 8 0), Point(5 0, 0 0), Point(0 0, 0 0); cout “Side 1: “ r length1() end1; cout “Side 2: “ r length2() end1; cout “Side 3: “ r length3() end1; cout “area: “ r area() end1; return 0; 三、综合应用题

9、 3 请使用 VC6或使用【答题】菜单打开考生文件夹 proj3下的工程 proj3,其中声明的 DataList类,是一个用于表示数据表的类。 sort成员函数的功能是将当前数据表中的元素升序排列。请编写这个 sort函数。程序的正确输出应为: 排序前: 7, 1, 3, 11, 6, 9, 12, 10, 8, 4, 5, 2 排序后: 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12 要求: 补充编制的内容写在 “ *333*”与 “ *666*”两行之间。不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out dat中。输出函数 writeToFil

10、e已经编译为 obj文件,并且在本程序调用。 DataList h#include iostream using namespace std; class DataList数据表类 int len; double * d; public: DataList(int len, double data NULL); DataList()deleted; ) int length()conStreturnfen; 数据表长度 (即数据元素的个数 ) double getElement(int i)constreturn di; void sort();数据表排序 void show()const;显

11、示数据表 ; void writeToFile(char *, constDataList&); main, cpp #include“DataList h“ DataList DataList(int len, double data): fen(1en) d new doublelen; for(int i 0; i len; i ) di (data NULL?0 0: datai); void DataList sort()数据表排序 *333* *666* void DataList show()const 显示数据表 for(int i 0; i len 1; i )cout di

12、 “, “; cout dlen 1 end1; int main() double s 7, 1, 3, 11, 6, 9, 12, 10, 8, 4, 5, 2; DataList list(12, s); cout “排序前: “; list show(); list sort(); cout end1 “排序后: “; list show(); writeToFile(“, list); return 0; 国家二级 C+机试(操作题)模拟试卷 288答案与解析 一、基本操作题 1 【正确答案】 (1)this color color; (2)const char getName()c

13、onstretum * name; (3)Dog dog1(“Hoho“, WHITE), dog2(“Haha“, BLACK), dog3(“Hihi“,OTHER ); 【试题解析】 (1)主要考查考生对 strcpy函数的掌握,如果看到上一条语句strcpy(this name, name);,就以为本条语句也要用 strcpy函数来赋值,这是错误的。 Strcpy函数只能复制字符串 ,根据类的私有成员声明可知, color是DOGCOLOR型的,这里直接使用赋值语句 “ ”即可。 (2)主要考查考生对函数返回值的掌握,先解读语句 const char * getName()const

14、return * name; ,要返回的是一个 const的字符指针,同时函数内的值不能改变, name在类的私有成员声明中是个字符数组, *name代表字符数组而不是字符指针,问题就出来了,需要修改返回类型: const char getName()constreturn, lc *name; 。 (3)语法错误,定义变量时,变量之间应使用 “, ”分开。 二、简单应用题 2 【正确答案】 (1)const Point& p (2)p1(p1), p2(p2) (3)Point p1, Point p2, Point p3 (4)(lengthl() length2() length3()

15、2 【试题解析】 (1)主要考查考生对函数形参的掌握,由函数的注释可知有本坐标点到达某个坐标点类的距离,再根据函数体 return sqrt(x p x)*(x p x) (y p y)*(y p y);可知,该坐标点类名为 p,因此可以知道形参为 Point&p,为了不改变该坐标点的值,前面要加上 const。 (2)主要考查考生对构造函数的掌握,对于常变量型私有成员 const Point p1,p2,只能用成员初始化列表进行赋值。 (3)主要考查考生对构造函数的掌握,由空格后面的语句: p1(p1), p2(p2),p3(p3)可知,该构造函数需要进行成员列表初始化,再看类的私有成员 c

16、onst Point p1, p2, p3,可知 p1, p2, p3是 Point类型,因此形参为 Point p1, Point p2, Point p3。 (4)主要考查考生对成员函数的掌握,根据函数注释,可知本函数要求计算三角形面积,再看题目的提示: s (a b c) 2。可知空格处要填的是三角形的三条边之和除以 2,而求边长的函数已经给出,这里直接调用即可。 三、综合应用题 3 【正确答案】 for(int 1 0; 1 len; 1)从头遍历数组 d for(int j i; j len; j)从 i i处遍历数组 d if(di dj) di和 dj比较人,如果大于,就 di和 dj交换 int temp di; 把临时整型变量 temp赋值为 di di dJ; 把 dj赋值给 di dj temp; 把 temp值赋给 dj 【试题解析】 本题使用最简单的冒泡排序算法,首先明确要排序的动态数组 d,其长度为 len,在此可以使用两个下标 i和 j相比较,当 di dj时,数组内的值利用中间变量 temp进行交换。

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