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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、国家二级 C+机试(操作题)模拟试卷 333 及答案解析(总分:10.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj1 下的工程 projl。程序中位于每个“ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应为: value=63 number=1 注意:只修改每个“ERROR*found*”下的那一行,不要改动程序中的其他内容。#includeiostreamusing namespace std;class MyClasS int*P; const int N;publi

2、c:ERROR*found* MyClass(int val):N=1 P=new int; *P=val; ERROR*found* 一 MyClass()delete*P;) friend void print(MyClassobj);;ERROR* found*void MyClass:print(MyClassobj) cout”value=”* (objP) end1; cout”number=” objNend1;int main() MyClass obj(63);print(obj); return 0;(分数:2.00)_二、简单应用题(总题数:2,分数:4.00)2.请使用

3、 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2。该工程中包含一个程序文件maincpp,其中有“书”类 Book 及其派生出的“教材”类 TeachingMaterial 的定义,还有主函数 main的定义。请在程序中“*found*”下的横线处填写适当的代码,然后删除横线,以实现上述类定义和函数定义。此程序的正确输出结果应为: 教材名:C+语言程序设计 页 数:299 作 者:张三 相关课程:面向对象的程序设计 注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。#includeiostreamusing namesp

4、ace std;claSS Book “书”类 char*title;/书名 int num_pages;页数 char*writer; 作者姓名 public: Book(const char*the title,int pages,const char*thewriter):num_pages(pages) title=new charstrlen(the title)+1; strcpy(title,the_title); *found* strcpy(writer,the_writer); /*found* 一 Book()_ int numOfPages()constreturn n

5、umpaqes;) 返回书的页数 const char*theTitle()constre-turn title;) 返回书名 const char*theWriter()constre-turn writer; 返回作者名,class TeachingMaterial:public Book“教材”类 char*course;public: TeachingMaterial(const char*the title,int pages,const char*the writer,const char*the course)*found* :_ course=new charstrlen(th

6、e course)+1; strcpy(course,the course); TeachingMaterial()deletecourse; const char*theCourse()constre-turn course;) 返回相关课程的名称;int main()TeachingMaterial a book(”C+语言程序设计”,299,“张三”,”面向对象的程序设计”); cout“教材名:“a booktheTitle()end1 ”页数:”abooknumOfPages()endl ”作 者:”a booktheWriter()end1 /*found*”相关课程:”_; co

7、utend1; return 0;(分数:2.00)_3.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2,该工程中含有一个源程序文件proj2cpp,请将堆栈类的定义补充完整。使程序的输出结果为: The element of stack are:4 3 2 1 注意:请勿修改主函数 main 和其他函数中的任何内容,只在横线处编写适当代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。proj2cpp#includeiostreamus ing namespace std;const int Size=5;class Stack;class

8、 Iternpublic:/*found*Item(const int)构造函数 对 item 进行初始化 private: int item; Item*next; friend class Stack; ; class Stack public: Stack():top(NULL) 一 Stack(); int Pop(); void Push(const int*found* _; 释放 P 所指向的节点 p=q; int Stack:Pop() Item*temp; int ret;/*found* _; 使 temp 指向栈顶节点 ret=top一item; top=top 一nex

9、t; delete temp; return ret;void Stack:Push(const intval) Item*temp=new Item(val);/*found*_;使新节点的 next 指针指向栈顶数据 top=temp;int main() Stack s; for(int i=1;iSize;i+) sPush(i); cout”The element of stack are:”; for(i=1;iSize;i+) coutsPop()t; return 0 ;(分数:2.00)_三、综合应用题(总题数:2,分数:4.00)4.请使用 VC6 或使用【答题】菜单打开考

10、生文件夹 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*”两行之间。不得修改程序的其他部分。注意:程序最后将结果输出到文件 outdat 中。输出函数 writeToFile 已经编译为 obj 文件,并且在本程序调用。/DataListh#includeiostre

11、amusing namespace std;class DataList数据表类 int len; double*d;public: DataList(int len,double data=NULL); 一 DataList()deleted;) int length()constreturn len;)数据表长度(即数据元素的个数) double getElement(int i)constre-turn di; void sort();数据表排序 void show()const;显示数据表 ; void writeToFile (char *, const DataList); mai

12、ncpp #include”DataListh DataList:DataList(int len,double data):len(len) d=new double1en; for(int i=0;ilen;i+) di=(data=NULL?00:data i); void DataList:sort()数据表排序 *333* *666* void DataList:show()const /显示数据表 for(int i=0;ilen 一 1;i+)coutdi“,“; coutdlen 一 1endl; int main() double S=7,1,3,11,6,9,12,10,8

13、,4,5,2; DataList list(12,s); COUt“排序前:“; listshow(); listsort(); coutendl“排序后:“; listshow(); writeToFile(”,list); return 0; (分数:2.00)_5.请使用 VC6 或使用【答题】菜单打开考生目录 proj3 下的工程文件 proj3,此工程中包含一个源程序文件 proj3cpp,其功能是从文本文件 indat 中读取全部整数,将整数序列存放到 intArray 类的对象中,然后建立另一对象 myArray,将对象内容赋值给 myArray。类 intArray 重载了“=

14、”运算符。程序中给出了一个测试数据文件 input,不超过 300 个的整数。程序的输出是: 10 11 13 16 20 要求: 补充编制的内容写在“*333*”与“*666*”之间。实现重载赋值运算符函数,并将赋值结果在屏幕输出。格式不限。不得修改程序的其他部分。 注意:程序最后将结果输出到文件 outdat 中。输出函数 writeToFile 已经编译为 obj 文件,并且在本程序中调用。/intArray,hclas S intArrayprivate: int*array; int length;public: intArray(char*filename); intArray()

15、; intArrayvoid writeToFile(const char*path);maincpp#includeioStream#includefstream#includecstring#include”intArrayh”using namespace std;intArray:intArray() length=10; array=new intlength;intArray:intArray(char*filename) ifstream myFile(filename); array=new int300; length=0; while(myFilearray1ength+)

16、 length 一一; myFileclose();intArrayERROR* found*void MyClass:print(MyClassobj) cout”value=”* (objP) end1; cout”number=” objNend1;int main() MyClass obj(63);print(obj); return 0;(分数:2.00)_正确答案:(正确答案:(1)MyClass(int Val):N(1) (2)MyClass()deletep; (3)void print(MyClassobj)解析:解析:(1)主要考查考生对构造函数的掌握,在这里不能使用赋

17、值语句。 (2)主要考查考生对析构函数的掌握,析构函数的 delete 语句要使用标识符“”,即 deletep;。 (3)主要考查考生对友元函数的掌握,友元函数并不属于类,因此定义时前面不用加类名和作用域符号。二、简单应用题(总题数:2,分数:4.00)2.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2。该工程中包含一个程序文件maincpp,其中有“书”类 Book 及其派生出的“教材”类 TeachingMaterial 的定义,还有主函数 main的定义。请在程序中“*found*”下的横线处填写适当的代码,然后删除横线,以实现上述类定义和函数定义。

18、此程序的正确输出结果应为: 教材名:C+语言程序设计 页 数:299 作 者:张三 相关课程:面向对象的程序设计 注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。#includeiostreamusing namespace std;claSS Book “书”类 char*title;/书名 int num_pages;页数 char*writer; 作者姓名 public: Book(const char*the title,int pages,const char*thewriter):num_pages(pages) title=new

19、charstrlen(the title)+1; strcpy(title,the_title); *found* strcpy(writer,the_writer); /*found* 一 Book()_ int numOfPages()constreturn numpaqes;) 返回书的页数 const char*theTitle()constre-turn title;) 返回书名 const char*theWriter()constre-turn writer; 返回作者名,class TeachingMaterial:public Book“教材”类 char*course;pu

20、blic: TeachingMaterial(const char*the title,int pages,const char*the writer,const char*the course)*found* :_ course=new charstrlen(the course)+1; strcpy(course,the course); TeachingMaterial()deletecourse; const char*theCourse()constre-turn course;) 返回相关课程的名称;int main()TeachingMaterial a book(”C+语言程序

21、设计”,299,“张三”,”面向对象的程序设计”); cout“教材名:“a booktheTitle()end1 ”页数:”abooknumOfPages()endl ”作 者:”a booktheWriter()end1 /*found*”相关课程:”_; coutend1; return 0;(分数:2.00)_正确答案:(正确答案:(1)writer=new charstrlen(the_writer)+1; (2)deletetitle,writer; (3)Book(the_title,pages,the_writer) (4)a_booktheCourse()next=top)解

22、析:解析:(1)主要考查构造函数,对私有成员进行初始化,即 item(val)。 (2)主要考查使用 delete语句释放指针,一般格式为:delete+指针。 (3)指向栈顶节点的是 top 指针,要使 temp 指向栈顶节点,故使用语句 temp=top;。 (4)指向栈顶节点的是 top 指针,要使新节点的 next 指针指向栈顶数据,故使用语句 temp 一next=top;。三、综合应用题(总题数:2,分数:4.00)4.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj3 下的工程 proj3,其中声明的 DataList 类,是一个用于表示数据表的类。sort 成员函数的

23、功能是将当前数据表中的元素升序排列。请编写这个 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*”两行之间。不得修改程序的其他部分。注意:程序最后将结果输出到文件 outdat 中。输出函数 writeToFile 已经编译为 obj 文件,并且在本程序调用。/DataListh#includeiostreamusing namespace std;class DataList数据表类 int len; double*d;pub

24、lic: DataList(int len,double data=NULL); 一 DataList()deleted;) int length()constreturn len;)数据表长度(即数据元素的个数) double getElement(int i)constre-turn di; void sort();数据表排序 void show()const;显示数据表 ; void writeToFile (char *, const DataList); maincpp #include”DataListh DataList:DataList(int len,double data)

25、:len(len) d=new double1en; for(int i=0;ilen;i+) di=(data=NULL?00:data i); void DataList:sort()数据表排序 *333* *666* void DataList:show()const /显示数据表 for(int i=0;ilen 一 1;i+)coutdi“,“; coutdlen 一 1endl; int main() double S=7,1,3,11,6,9,12,10,8,4,5,2; DataList list(12,s); COUt“排序前:“; listshow(); listsort(

26、); coutendl“排序后:“; listshow(); writeToFile(”,list); return 0; (分数:2.00)_正确答案:(正确答案:for(int 1 =0;1 len; +1) 从头遍历数组 d for(int j =i;j len; +j) 从 i+1 处遍历数组 d if(di dj) di和 dj比较人,如果大于,就 di和 dj值交换 int temp=di; 把临时整型变量 temp 赋值为 di di =dj; 把 dj赋值给 di dj=temp; 把 temp 值赋给 dj )解析:解析:本题使用最简单的冒泡排序算法,首先明确要排序的动态数组

27、 d,其长度为 len,在此可以使用两个下标 i 和 j 相比较,当 didj时,数组内的值利用中间变量 temp 进行交换。5.请使用 VC6 或使用【答题】菜单打开考生目录 proj3 下的工程文件 proj3,此工程中包含一个源程序文件 proj3cpp,其功能是从文本文件 indat 中读取全部整数,将整数序列存放到 intArray 类的对象中,然后建立另一对象 myArray,将对象内容赋值给 myArray。类 intArray 重载了“=”运算符。程序中给出了一个测试数据文件 input,不超过 300 个的整数。程序的输出是: 10 11 13 16 20 要求: 补充编制的

28、内容写在“*333*”与“*666*”之间。实现重载赋值运算符函数,并将赋值结果在屏幕输出。格式不限。不得修改程序的其他部分。 注意:程序最后将结果输出到文件 outdat 中。输出函数 writeToFile 已经编译为 obj 文件,并且在本程序中调用。/intArray,hclas S intArrayprivate: int*array; int length;public: intArray(char*filename); intArray(); intArrayvoid writeToFile(const char*path);maincpp#includeioStream#inc

29、ludefstream#includecstring#include”intArrayh”using namespace std;intArray:intArray() length=10; array=new intlength;intArray:intArray(char*filename) ifstream myFile(filename); array=new int300; length=0; while(myFilearray1ength+) length 一一; myFileclose();intArray& intArray: operator =(const intArray

30、src)if(array!=NULL)deletearray;length=srclength;array=new intlength;*333*666* return*thiS;intArray:一intArray() deletearray;void intArray:show() int step=0; for(int i=0;ilength;i=i+step) coutarrayiendl; step+; void main() intArray*arrayP=new intArray(”inputdat”); intArray myArray; myArray=*arrayP; (*

31、arrayP)show(); delete arrayP; writeToFile(”); (分数:2.00)_正确答案:(正确答案:for(int i=0;ilength;i+) 遍历对象 src 中的数组 array,然后依次把值放进数组 array 中 arrayi =srcarrayi;)解析:解析:主要考查考生对运算符重载的掌握,该函数要重载运算符“=”,该运算符的意思是赋值。先看该函数的其他语句: if(array!=NULL)deletearray; length=src1ength; array=new int1ength; 第一条语句是把原来动态数组释放,第二条语句是把形参 SYC 的成员 length 赋值给变量length,第三条语句是给指针 array 分配内存。接下来要把动态数组中的值逐个赋给 array 数组,在这里使用 for 循环语句,循环变量 i 的范围是 0 一 length,并进行赋值操作。

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