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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C+机试(操作题)-试卷 50 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.请使用 VC6 或使用【答题】菜单打开考生文件夹 projl 下的工程 pmjl,此工程包含有一个源程序文件projlcpp。其中位于每个注释“ERROR * found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为:(4,4)注意:只修改注释“ERROR *found*”的下一行语句,不要改动程序中的其他内容。projlcpp#includeiostreamusing namespace std;class Pointpublic:ERR

2、OR*found* Point(double x,double Y)一 X(x),y(Y) double GetX()constreturn x;) double GetY()constreturn_y;)ERROR*found*void Move (double xOff,double yOff)const x+=xOff;_y+=yOff;)protected: doublex;y; ; int main() Point pt(15,25); ptMove(25,15);ERROR*found* 以下语句输出 pt 成员 x 和 y 的值cout(pt_X ,pt_y)endl; retu

3、rn 0; (分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2,此工程包含有一个源程序文件pmj2cpp。其中定义了 Base1 类、Base2 类和 Derived 类。Base1 是一个抽象类,其类体中声明了纯虚函数 Show。Base2 类的构造函数负责动态分配一个字符数组,并将形参指向的字符串复制到该数组中,复制功能要求通过调用 strcpy 函数来实现。Derived 类以公有继承方式继承 Basel 类,以私有继承方式继承Base2 类。在 Derived 类的构造函数的成员初始化列

4、表中调用 Base 类的构造函数。请在程序中的横线处填写适当的代码,然后删除横线,以完成 Base1、Base和 Derived 类的功能。此程序的正确输出结果应为: Im a derived class 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。proj2cpp#includeiostream#includecstringusing namespace std;class Baselpublic:*found*下列语句需要声明纯虚函数Show; ; class Base2 protected: char*;; Base2(const cha

5、r*s)_P=new charstrlen(s)+1;*found*下列语句将形参指向的字符串常量复制到该类的字符数组中;?Base2()delete-j);),*found*Derived 类公有继承 Basel,私有继承 Base2 类 class Derived:public:*found*以下构造函数调用 Base2 类构造函数 Derived(const char*s): void Show()cout_pendl;);int main()Basel*pb=new Derived(“Im a derived class”); pb 一Show(); delete pb; return

6、 0;(分数:2.00)_三、综合应用题(总题数:1,分数:2.00)3.请使用 VC6 或使用【答题】菜单打开考生目录 proj3 下的工程文件 proj3,此工程包含一个源程序文件proj3epp,其功能是从文本文件 indat 中读取全部整数,将整数序列存放到 intArray 类的对象myAay 中,然后对整数序列按非递减排序,最后由函数 writeToFile 选择序列中的部分数据输出到文件outdat 中。文件 indat 中的整数个数不大于 300 个。要求:补充编制的内容写在“*333*”与“*666*”两行之间。实现对整数序列按非递减排序,并将排序结果在屏幕上输出。不得修改程

7、序的其他部分。注意:程序最后已将结果输出到文件outdat 中。输出函数 writeToFile 已经给出并且调用。proj 3cpp#includeiostream#includefstream#includecstringusing namespace std;class intArrayprivate: int*array;整数序列首地址 int length;序列中的整数个数 public: 构造函数,从文件中读取数据用于初始化新对象。参数是文件名 intArray(char*filename); void sort();对整数序列按非递减排序 一 intArray(); void w

8、riteToFi le(char*fi lename); ); intArray:intArray(char*filename) ifstream myFile(filename); int len=300; array=new int1en; length=0; while(myFilearray1ength+); length 一一; myFileclose(); void intArray:sort() *333* *666* intArray:intArray() deletearray; void intArray:writeToFile(char。 filename) int st

9、ep=0; ofstream outFile(filename); for(int i=0;ilength;i=i+step)outFilearrayiendl;step+;outFileclose();void main() intArray myArray(”indat”); myArraysort(); myArraywriteToFile(”outdat”);(分数:2.00)_国家二级 C+机试(操作题)-试卷 50 答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.请使用 VC6 或使用【答题】菜单打开考生文件夹 projl 下的工程

10、pmjl,此工程包含有一个源程序文件projlcpp。其中位于每个注释“ERROR * found*”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为:(4,4)注意:只修改注释“ERROR *found*”的下一行语句,不要改动程序中的其他内容。projlcpp#includeiostreamusing namespace std;class Pointpublic:ERROR*found* Point(double x,double Y)一 X(x),y(Y) double GetX()constreturn x;) double GetY()constreturn_y;)ERR

11、OR*found*void Move (double xOff,double yOff)const x+=xOff;_y+=yOff;)protected: doublex;y; ; int main() Point pt(15,25); ptMove(25,15);ERROR*found* 以下语句输出 pt 成员 x 和 y 的值cout(pt_X ,pt_y)endl; return 0; (分数:2.00)_正确答案:(正确答案:(1)Point(double x,double y):一 x(x),一 y(y)或 Point(double x,double y)x:x;y=y; (2)

12、void Move(double xOff,double yOff) (3)cout(ptGetX(),)endl;)解析:解析:本题主要考查 Point 类,其中涉及构造函数、成员函数及成员函数的调用。构造函数的语法经常考查到,一般会考查形参的类型及名称,本题考查的比较特别,是考查函数成员初始化列表的基本知识。 【解题思路】 (1)主要考查的是构造函数的成员初始化列表的语法,在成员列表之前必须加“:”。(2)主要考查成员函数中 const 的使用,先看 Move 函数的函数体: _x+=xOff;y+=yOff; 可以看到Point 类的两个私有成员一 x 和一 y 的值都发生了变化,因此

13、Move 函数不能使用 eonst,因为只有在函数内不改变类的成员的值时才能使用 const。 (3)主要考查私有成员不能被类外函数调用的知识。题目要求输出 pt 成员x 和-y 的值,从 Point 类中的函数 doubleGetX()constreturn-x;和 double GetY()eonstreturny;,可以分别得到一 x 和一 y 的值,因此这里使用语句 cout(ptGetX(),ptGetY()二、简单应用题(总题数:1,分数:2.00)2.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2,此工程包含有一个源程序文件pmj2cpp。其中

14、定义了 Base1 类、Base2 类和 Derived 类。Base1 是一个抽象类,其类体中声明了纯虚函数 Show。Base2 类的构造函数负责动态分配一个字符数组,并将形参指向的字符串复制到该数组中,复制功能要求通过调用 strcpy 函数来实现。Derived 类以公有继承方式继承 Basel 类,以私有继承方式继承Base2 类。在 Derived 类的构造函数的成员初始化列表中调用 Base 类的构造函数。请在程序中的横线处填写适当的代码,然后删除横线,以完成 Base1、Base和 Derived 类的功能。此程序的正确输出结果应为: Im a derived class 注意

15、:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。proj2cpp#includeiostream#includecstringusing namespace std;class Baselpublic:*found*下列语句需要声明纯虚函数Show; ; class Base2 protected: char*;; Base2(const char*s)_P=new charstrlen(s)+1;*found*下列语句将形参指向的字符串常量复制到该类的字符数组中;?Base2()delete-j);),*found*Derived 类公有继承 Bas

16、el,私有继承 Base2 类 class Derived:public:*found*以下构造函数调用 Base2 类构造函数 Derived(const char*s): void Show()cout_pendl;);int main()Basel*pb=new Derived(“Im a derived class”); pb 一Show(); delete pb; return 0;(分数:2.00)_正确答案:(正确答案:(1)virtualvoid Show()=0 (2)strcpy(_p,s) (3)public Basel,private Base2 (4)Base2(s)

17、解析:解析:本题主要考察抽象类 Base1、基类 Base2 及其派生类 Derived,其中涉及纯虚函数、构造函数、析构函数、派生类构造函数等知识点。编写抽象类的纯虚函数时要先看清在派生类中该函数的定义,注意返回值、参数类型、有无 eonst 关键字几个要点。派生类的构造函数一定要使用成员列表法先对基类初始化。 【解题思路】 (1)主要考查的是纯虚函数的定义。题目要求声明纯虚函数 Show,因此首先看Basel 类的派生类 Deftred 类中 Show 函数的定义: void Show() cout-p三、综合应用题(总题数:1,分数:2.00)3.请使用 VC6 或使用【答题】菜单打开考

18、生目录 proj3 下的工程文件 proj3,此工程包含一个源程序文件proj3epp,其功能是从文本文件 indat 中读取全部整数,将整数序列存放到 intArray 类的对象myAay 中,然后对整数序列按非递减排序,最后由函数 writeToFile 选择序列中的部分数据输出到文件outdat 中。文件 indat 中的整数个数不大于 300 个。要求:补充编制的内容写在“*333*”与“*666*”两行之间。实现对整数序列按非递减排序,并将排序结果在屏幕上输出。不得修改程序的其他部分。注意:程序最后已将结果输出到文件outdat 中。输出函数 writeToFile 已经给出并且调用

19、。proj 3cpp#includeiostream#includefstream#includecstringusing namespace std;class intArrayprivate: int*array;整数序列首地址 int length;序列中的整数个数 public: 构造函数,从文件中读取数据用于初始化新对象。参数是文件名 intArray(char*filename); void sort();对整数序列按非递减排序 一 intArray(); void writeToFi le(char*fi lename); ); intArray:intArray(char*fi

20、lename) ifstream myFile(filename); int len=300; array=new int1en; length=0; while(myFilearray1ength+); length 一一; myFileclose(); void intArray:sort() *333* *666* intArray:intArray() deletearray; void intArray:writeToFile(char。 filename) int step=0; ofstream outFile(filename); for(int i=0;ilength;i=i

21、+step)outFilearrayiendl;step+;outFileclose();void main() intArray myArray(”indat”); myArraysort(); myArraywriteToFile(”outdat”);(分数:2.00)_正确答案:(正确答案:for(int i=0;ilength; +i) 遍历整个数组 for(int j =i;j length; +j) 从 i+遍历整数组 if(arrayi arrayj) 如果 arragiarrayj,把arrayi与 ar rayi进行对换 int temp; 定义一个临时变 量 temp te

22、mp=arrayi;把array i值放到变量 temp arrayi=arrayj;把 arrayj值赋给 arrayi arrayj =terap; 把变量 temp 存放在值 arrayj中 for(int a:0;alength; +a) 遍历数组,把数组中的所有元素打印到控制台上 coutarraya”;)解析:解析:本题主要考查 intArray 类,其中涉及构造函数、排序函数和析构函数。常用的排序算法有冒泡排序、选择排序、插入排序、堆排序等。 【解题思路】题目要求对整数序列按非递减排序,要排序就必须要有比较,因此定义两个下标 i 和 j,按题目非递减排序要求,当 arrayi比 arrayj大时就交换其值,利用中间变量 temp 来实现。 【解题宝典】排序算法有多种,其基本思想是相同的,即先遍历,后比较,再交换。不同之处在于它们遍历数列的顺序不同。考生可选择一至两种算法重点理解。

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