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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

【计算机类职业资格】二级C++机试-28及答案解析.doc

1、二级 C+机试-28 及答案解析(总分:100.00,做题时间:90 分钟)一、1改错题(总题数:1,分数:30.00)1.使用 VC6 打开考生文件夹下的工程 test23_1,此工程包含一个源程序文件 test23_1.cpp,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:iizO1222源程序文件 test23_1.cpp 清单如下:#includeiostream.h#includestdio.hclass innerclassint x; public:/*found*/innerclass(int z) x=z; cout“iz“endl;/*found*/void

2、 write( ) print(“%d/n“,x);class outerclassint y;innerclass g;innerclass *h;public:outerclass(int a);void write( ) printf(“%d/n“,y); void write_inner_g() g.write(); void write_inner_h() h-write();outerclass:outerclass(int a) /*found*/h=new innerclass(12);cout“o“endl; int main ( ) outerclass ob(22);ob

3、write_inner_h();ob.write();return 1; (分数:30.00)填空项 1:_二、2简单应用题(总题数:1,分数:40.00)2.请编写一个函数 void bubble(double data,int length),其中 data 是一维数组,存放比较的数据,length 是数组中存放元素的个数,用冒泡法将数据(个数可变)捧序后由小到大输出。冒泡法是常用的排序算法,这种算法执行效率不高,但比较简单,就是将相邻的两个数据作比较,把较小的数据交换到前面。纵向看来,交换过程中较小的数据就好像水中的气泡不断浮起。要求使用 for 循环实现算法。注意:部分源程序已存在文

4、件 test23_2.cpp 中。请勿修改主函数 main 和其他函数中的任何内容,仅在函数 bubble 的花括号中填写若干语句。文件 test23_.cpp 的内容如下:#includeiostream.hvoid bubble(double data,int length)void main ()int n;cout “请输入数据的个数“;cinn;double* ddata = new doublen;for(int i = 0; i n; i+)cout“No.“i+1“: “;cinddatai;bubble (ddata, n);cout“排序后输出数据:“endl;for(i

5、 O; in; i+)cout“No.“i+1“:“;coutddataiendl;(分数:40.00)_三、3综合应用题(总题数:1,分数:30.00)3.使用 VC6 打开考生文件夹下的工程 test23_3,此工程包含一个源程序文件 test23_3.cpp,其中定义了类X 和它的友元类 Y,但它们的定义并不完整。请按要求完成下列操作,将程序补充完整。(1)将类 X 的静态数据成员 y 初始化为 1。请在注释“/*1*”之后添加适当的语句。(2)完成类 Y 的构造函数 Y(int i,int j)的定义,将参数 i 赋值给类 Y 的数据成员,X 的对象 a 中的数据成员 x,并且把参数

6、 j 赋值给类 X 的数据成员 y,请在注释“/*2*”之后添加适当的语句。(3)完成类 Y 的成员函数 void Display()的定义,将 Y 的数据成员,X 的对象 a 中的数据成员 x 和类 X 的数据成员 y 按照“x=_,y=_”的形式显示出来(“_”代表一个数字),请在注释“/*3*”之后添加适当的语句。输出结果如下:x=5,y=lx=6,y=9x=5,y=9注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。源程序文件 test23_3.cpp 清单如下:includeiostream.hclass Xfriend class Y;public:void Set(in

7、t i) x=i;void Display()cout“x=“x“,“;cout“y=“yendl;private:int x;static int y;class Ypublic:Y(int i, int j)void Display(); private:X a;/*1* Y:Y(int i, int j) /*2* void Y:Display()/*3* void main ( ) X b;b.Set(5);b.Display();Y c(6,9);c.Display();b.Display(); (分数:30.00)_二级 C+机试-28 答案解析(总分:100.00,做题时间:90

8、 分钟)一、1改错题(总题数:1,分数:30.00)1.使用 VC6 打开考生文件夹下的工程 test23_1,此工程包含一个源程序文件 test23_1.cpp,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:iizO1222源程序文件 test23_1.cpp 清单如下:#includeiostream.h#includestdio.hclass innerclassint x; public:/*found*/innerclass(int z) x=z; cout“iz“endl;/*found*/void write( ) print(“%d/n“,x);class ou

9、terclassint y;innerclass g;innerclass *h;public:outerclass(int a);void write( ) printf(“%d/n“,y); void write_inner_g() g.write(); void write_inner_h() h-write();outerclass:outerclass(int a) /*found*/h=new innerclass(12);cout“o“endl; int main ( ) outerclass ob(22);ob.write_inner_h();ob.write();return

10、 1; (分数:30.00)填空项 1:_ (正确答案:(1)错误:缺少缺省的构造函数正确:innerclass()cout“i“endl;(2)错误:void write()print(“%d/n“,x);正确:void write()printf(“%d/n“,x);(3)错误:缺少赋值语句正确:y=a;)解析:解析(1)主要考查考生对于派生类调用基类构造函数的应用,此处必须定义缺省的构造函数(g 调用);(2)主要考查考生对于格式化输出的掌握,应该使用函数 printf,其中的%d 表示是输出整型: (3)主要考查考生对于构造函数作用的掌握,只有在此处赋值才能将 22 显示出来,因为构造

11、函数在声明对象的时候会被自动的调用。二、2简单应用题(总题数:1,分数:40.00)2.请编写一个函数 void bubble(double data,int length),其中 data 是一维数组,存放比较的数据,length 是数组中存放元素的个数,用冒泡法将数据(个数可变)捧序后由小到大输出。冒泡法是常用的排序算法,这种算法执行效率不高,但比较简单,就是将相邻的两个数据作比较,把较小的数据交换到前面。纵向看来,交换过程中较小的数据就好像水中的气泡不断浮起。要求使用 for 循环实现算法。注意:部分源程序已存在文件 test23_2.cpp 中。请勿修改主函数 main 和其他函数中的

12、任何内容,仅在函数 bubble 的花括号中填写若干语句。文件 test23_.cpp 的内容如下:#includeiostream.hvoid bubble(double data,int length)void main ()int n;cout “请输入数据的个数“;cinn;double* ddata = new doublen;for(int i = 0; i n; i+)cout“No.“i+1“: “;cinddatai;bubble (ddata, n);cout“排序后输出数据:“endl;for(i = O; in; i+)cout“No.“i+1“:“;coutddata

13、iendl;(分数:40.00)_正确答案:(void bubble(double data,int length)int segment;int loop;double temp;for(segment=0;segment=length-2;segment+)for(1oop=length-2;loop=segment;loop-)if(dataloop+1dataloop)temp=dataloop;dataloop =data loop+1;dataloop+1=temp;)解析:解析本题考查的是考生使用 for 循环和常用的冒泡排序法的综合水平。冒泡排序法就是将相邻的两个数据作比较,把

14、较小的数据交换到前面,以此类推。这是经典的算法应该掌握。三、3综合应用题(总题数:1,分数:30.00)3.使用 VC6 打开考生文件夹下的工程 test23_3,此工程包含一个源程序文件 test23_3.cpp,其中定义了类X 和它的友元类 Y,但它们的定义并不完整。请按要求完成下列操作,将程序补充完整。(1)将类 X 的静态数据成员 y 初始化为 1。请在注释“/*1*”之后添加适当的语句。(2)完成类 Y 的构造函数 Y(int i,int j)的定义,将参数 i 赋值给类 Y 的数据成员,X 的对象 a 中的数据成员 x,并且把参数 j 赋值给类 X 的数据成员 y,请在注释“/*2

15、之后添加适当的语句。(3)完成类 Y 的成员函数 void Display()的定义,将 Y 的数据成员,X 的对象 a 中的数据成员 x 和类 X 的数据成员 y 按照“x=_,y=_”的形式显示出来(“_”代表一个数字),请在注释“/*3*”之后添加适当的语句。输出结果如下:x=5,y=lx=6,y=9x=5,y=9注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。源程序文件 test23_3.cpp 清单如下:includeiostream.hclass Xfriend class Y;public:void Set(int i) x=i;void Display()cou

16、t“x=“x“,“;cout“y=“yendl;private:int x;static int y;class Ypublic:Y(int i, int j)void Display(); private:X a;/*1* Y:Y(int i, int j) /*2* void Y:Display()/*3* void main ( ) X b;b.Set(5);b.Display();Y c(6,9);c.Display();b.Display(); (分数:30.00)_正确答案:(1)int X:y=1;(2)a.x=i;X;y=j;(3)cout“X=“a.x“,“;cout“y=“X:yendl;)解析:解析本题主要考查考生对于友元类的定义和使用友元类访问的应用,注意(1)中类 X 的静态成员y 应该在类外初始化,而(2)和(3)中对于 x 和 y 不同的访问方式就是因为 y 是静态成员,是类 X 的所有对象公有的,必须使用作用域符“:”进行访问。

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