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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C+机试(操作题)模拟试卷 125及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 projl下的工程 projl,此工程中含有 个源程序文件 projl cpp。其中位于每个注释 “ERROR*found*”之后的 行语句存在错误。请改正这些错误,使程序的输出结果为: NUM=0 Value=1 注意:只修改注释 “ ERROR *found*”的下一行语句,不要改动程序中的其他内容。 projl cpp #include using namespace std; class MyClass int i; friend void Increment(

2、MyClass f); public: const int NUM; ERROR* found* MyClass(int i=0)NUM=0; _i=i; int GetValue()constreturn i; ) ; ERROR*found* void Increment()f i+; ) int main() MyClass obj; ERROR*found* MyClass: Increment(obj); cout #include #include using namespace std; class Score public: Score(double*S, int n): s(

3、S), n (n) double GetScore(int i)constreturn Si; ) void Sort(); private: double* S; int n; ; void Score: Sort() * found* for(int i=0; ii; J一一 ) _。 if(一 SJ using namespace std; clas s ValArray int*v; int Size; public: ValArray(const int*P, int n): Size(n) V=new int Size; for(int i=0; iSize; i+) vi=Pi;

4、 ValArray(const ValArray void writeToFile(const char*); main cpp #include“ValArray h” ValArray: ValArray(const ValArray& other) *333* *666* int main() const int a=l, 2, 3, 4, 5 J; ValArray v1(a, 5); ValArray V2(V1); for(int i=0; i5; i+) v2 setElement(i, 2); cout“ValArray vl=”; v1 print(cout); couten

5、dl; cout“ValArray v2=”; v2 print(cout); coutendl; writeToFile(“”); return 0; 国家二级 C+机试(操作题)模拟试卷 125答案与解析 一、基本操作题 1 【正确答案】 (1)MyClass(int i O): NUM(0) (2)void Increment(MyClass&f)f j+; (3)Increment(0bj); 【试题解析】 本题考查的是 MyClass类,其中涉及友元函数、构造函数、常量数据成员、成员函数和友元函数的调用。友元函数的定义要与函数声明相呼应,即返回值、参数类型、参数个数要一致。友元函数的

6、调用不需要使用类名和作用域。 【解题思路】 (1)主要考查考生对常量数据成员初始化方法的掌握,常量数据成员的初始化只能通过构造函数的成员初始化列表进行, 并且要使用关键字 const修饰。该题的前一条语句 const int NUM;,说明 NUM是常量数据成员。 (2)主要考查考生对友元函数的掌握,友元函数的定义与声明要一致,先看该友元函数的声明部分: friend void In crement(MyClass&f);,返回类型为 void,函数参数为 MyClass&f;再比较出错的语句: void Increment()f i+; ,错误在于该函数没有参数,应把 MyClass&f填在

7、括号内。 (3)主要考查友元函数的调用,友元函数并不属于类,因此调用友元函数 时不需要添加类名及作用域,只需要像调用普通函数一样即可。 【解题宝典】类的常量数据成员初始化必须使用成员初始化列表进行,否则必然出错。友元函数与普通函数的区别在于,友元函数可以通过对象名调用类的全部成员,包括私有成员。所有函数的声明和定义必须一致,包括函数返回值、参数类型、参数个数及有无 const关键字。 二、简单应用题 2 【正确答案】 (1)i+ (2)一 n1 (3)一 sj=一 sj1 (4)一 sj一 1 =t 【试题解析】 本题考查 Score类,其中涉及构造函数、成员函数和 排序算法。 【解题思路】

8、(1)主要考查 for循环语句,从题目要求可知循环变量 i要从 0到一 n一 2,因此 i要递增操作,即 i+。 (2)主要考查考生对冒泡排序的掌握,这里要求从后往前扫描,比较相邻两个元素,若后者小则交换,因此在这里下标 j要从最后开始,即 int j=一 n 1。 (3)考查交换算法,在 if语句中一 sj一 sj 1满足条件,则实现交换。因为已经把一 sj的值赋给了中间变量 t,所以这里要把一 sj一 1的值赋给一 sj,即一sj=一 sj一 1;。 (4)考查交换算法,这里只需把中间 变量 t中的值赋给 _sj 1即可。 【解题宝典】 本题考查的是考生对冒泡排序算法的掌握,要记住冒泡排序

9、的思想是两两比较待排序序列中的元素,并交换不满足顺序要求的各对元素,直到全部满足顺序要求为止。 三、综合应用题 3 【正确答案】 S1ze=other s1 ze; 把对象数组的大小赋值给 sizev=DeW int other size ; 根据对象数组的大小动态分配数组 vfor(int i=0; isize; +i) vi=other vi; 遍历整个对象的数组把 值 other vi放到数组 v中 【试题解析】 本题主要考查的是 ValArray类,其中涉及构造函数、成员函数和析构函数。题目要求编写 ValArray类的复制构造函数,以实现对象的深层复制。即填写 ValArray: ValArray(const ValArray&other)函数的函数体。 【解题思路】 主要考查考生对复制构造函数的掌握。由函数名: Val-Array: ValArray(const ValArray&other),知道要复制的对象是 other,对由 Val Array类的成员: int木 v; int size;知道要复制的内容是动态数组 v及整型变量 size。动态数组要使用new语句分配内存,最后利用 for循环语句来完成复制过程。

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