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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

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

1、二级 C+机试-160 及答案解析(总分:100.00,做题时间:90 分钟)一、1改错题(总题数:1,分数:30.00)使用 VC+6.0 打开考生文件夹下的源程序文件 1.cpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为Max is 7提示:max 函数川于找出两个数中的最大值,并作为函数值返回。注意:错误的语句在/*error*的下而,修改该语句即可。试题程序:#includeiostreamusing namespace std;/*error*int max(int a,int b)if(ab)int t=a;a=b;b=t;return b;int

2、main()int m=-3;int n=7;/*error*max(-3,n);cout“Max is“mend1;return 0;(分数:30.00)填空项 1:_填空项 1:_二、2简单应用题(总题数:1,分数:40.00)1.使用 VC+6.0 打开考生文件夹下的源程序文件 2.cpp。阅读下列函数说明和代码,完成空出部分的程序。实现函数 sort(int A,int n),用冒泡法对数组数据进行排序。所谓冒泡法,就是每次把相邻的两个数交换,较大的数交换到后面。这样下标从 0 到 n-1 的数与其后面相邻的数交换,可以把最大的数交换到数组的末端。进行 n 次下标从 0 到 n-1 的

3、交换,则数组变成有序的,并且按由大到小排序。注意:不能修改和删除程序的其他部分,也不能修改程序的结构。试题程序:#includeiostream.h#define N 10void sort(int AN,int n)int main()int AN=1,50,17,69,87,42,90,-6,0,-11;sort(A,10);for(int i=0;isizeof(A)/sizeof(int);i+)coutAi;coutend1;return 0;(分数:40.00)_三、3综合应用题(总题数:1,分数:30.00)使用 VC+6.0 打开考生文件夹下的源程序文件 3.cpp。其中定义的

4、类不完整,按要求完成下列操作,将类的定义补充完整。(1)利用 define 定义常量 TRUE 为 1,定义常量 FALSE 为 0,请在注释 1 后添加适当的语句。(2)在类 A2 前增加 A1 的声明,请在注释 2 后添加适当的语句。(3)在类 C1 中声明友元函数 bool func(A2a,A1b),请在注释 3 后添加适当的语句。(4)实现函数 bool func(A2obj1,A1obj2)的功能,检查两个类的值都为 TRUE,则返回 TRUE,请在注释 4 后添加适当的语句。注意:除在指定位置添加语句之外,不要改动程序中的其他内容。试题程序:#includeiostream.h/

5、*1*#define FALSE 0/*2*class A2private:bool m_A2;friend bool func(A2obj1,A1obj2);public:A2()m_A2=FALSE;public:void setA2(bool n)m_A2=n;Class A1private:bool m_A1;/*3*public:A1()m_A1=TRUE;public:void setA1(bool n)m_A1=n;bool func(A2obj1,A1obj2)/*4*returnint main()A2 obj0;A1 obj1;coutfunc(obj0,obj1)end1

6、;obj0.setA2(TRUE);obj1.setA1(TRUE);coutfunc(obj0,obj1)end1;return 0;(分数:30.00)填空项 1:_填空项 1:_填空项 1:_填空项 1:_二级 C+机试-160 答案解析(总分:100.00,做题时间:90 分钟)一、1改错题(总题数:1,分数:30.00)使用 VC+6.0 打开考生文件夹下的源程序文件 1.cpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为Max is 7提示:max 函数川于找出两个数中的最大值,并作为函数值返回。注意:错误的语句在/*error*的下而,修改该语句即可

7、。试题程序:#includeiostreamusing namespace std;/*error*int max(int a,int b)if(ab)int t=a;a=b;b=t;return b;int main()int m=-3;int n=7;/*error*max(-3,n);cout“Max is“mend1;return 0;(分数:30.00)填空项 1:_ (正确答案:应改为“int max(inta,intb)”。)解析:填空项 1:_ (正确答案:应改为“max(m,n);”。)解析:解析 由审题分析可知,max 函数采用传送引用的方式来传递参数,因此第 1 处的语句

8、应该为“int max(inta,intb)”。调用 max 时,传递引用时直接使用变量名即可,第 2 处的语句应改为“max(m,n)”。二、2简单应用题(总题数:1,分数:40.00)1.使用 VC+6.0 打开考生文件夹下的源程序文件 2.cpp。阅读下列函数说明和代码,完成空出部分的程序。实现函数 sort(int A,int n),用冒泡法对数组数据进行排序。所谓冒泡法,就是每次把相邻的两个数交换,较大的数交换到后面。这样下标从 0 到 n-1 的数与其后面相邻的数交换,可以把最大的数交换到数组的末端。进行 n 次下标从 0 到 n-1 的交换,则数组变成有序的,并且按由大到小排序。

9、注意:不能修改和删除程序的其他部分,也不能修改程序的结构。试题程序:#includeiostream.h#define N 10void sort(int AN,int n)int main()int AN=1,50,17,69,87,42,90,-6,0,-11;sort(A,10);for(int i=0;isizeof(A)/sizeof(int);i+)coutAi;coutend1;return 0;(分数:40.00)_正确答案:(int i,j,k,t;for(i=0;in-1;i+)for(k=i,j=i+1;jn;j+)if(AkAj) /如果前面的比后面的小则需要交换k=j

10、;if(k!=i)/交换t=Ai;Ai=Ak;Ak=t;)解析:解析 以数组“A=3,8,7,6,5,0,1,2,9,4”为例来说明具体的排序过程,第一次选择:第一步,从 A0=A9中找最大值 max 及下标 k,max=9,k=8;第二步,交换 a0与最大值 a8的值;第一次结束后 a0已存放了最大值,下一次比较就不必再经过它了,而从 a1开始,如此循环。从例中可以看出 10 个元素要进行 9 次比较,n 个元素要进行 n-1 次比较。设置两层循环,外层循环变量 i 从 0到 n-1,内层循环变量从 i 开始到 n-1,在内层循环中找最大值,如果最大值的下标 k 和 i 不同,则交换,实现选

11、择法排序。在内层循环体内,如果最大值的下标 k 和 i 不同,则用一个临时变量记录第 i 个元素,然后将第 k 个元素赋值给第 i 个元素,临时变量值赋给第 k 个元素,如此完成两个元素的交换。三、3综合应用题(总题数:1,分数:30.00)使用 VC+6.0 打开考生文件夹下的源程序文件 3.cpp。其中定义的类不完整,按要求完成下列操作,将类的定义补充完整。(1)利用 define 定义常量 TRUE 为 1,定义常量 FALSE 为 0,请在注释 1 后添加适当的语句。(2)在类 A2 前增加 A1 的声明,请在注释 2 后添加适当的语句。(3)在类 C1 中声明友元函数 bool fu

12、nc(A2a,A1b),请在注释 3 后添加适当的语句。(4)实现函数 bool func(A2obj1,A1obj2)的功能,检查两个类的值都为 TRUE,则返回 TRUE,请在注释 4 后添加适当的语句。注意:除在指定位置添加语句之外,不要改动程序中的其他内容。试题程序:#includeiostream.h/*1*#define FALSE 0/*2*class A2private:bool m_A2;friend bool func(A2obj1,A1obj2);public:A2()m_A2=FALSE;public:void setA2(bool n)m_A2=n;Class A1p

13、rivate:bool m_A1;/*3*public:A1()m_A1=TRUE;public:void setA1(bool n)m_A1=n;bool func(A2obj1,A1obj2)/*4*returnint main()A2 obj0;A1 obj1;coutfunc(obj0,obj1)end1;obj0.setA2(TRUE);obj1.setA1(TRUE);coutfunc(obj0,obj1)end1;return 0;(分数:30.00)填空项 1:_ (正确答案:应添加“#define TRUE 1”。)解析:填空项 1:_ (正确答案:应添加“class A1;

14、”。)解析:填空项 1:_ (正确答案:应添加“friend bool func(A2obj1,A1obj2);”。)解析:填空项 1:_ (正确答案:将“return”补充完整为“return obj1.m_A2=TRUEobj2.m_A1=TRUE;”。)解析:解析 #define 命令一般用一个指定的标识符(即宏名)来代表一个字符串,其定义形式一般为“#define 宏名(参数表)字符串”,因此第 1 处应添加“#define TRUE 1”。类声明格式为“class类名;”,故第 2 处应添加“class A1;”。友元不是本类的成员函数,在它的函数体内可以通过对象名来访问类的私有成员和保护成员。友元函数是在类声明中由关键字 friend 修饰的非成员函数,第 3 处应应添加“friend bool func(A2obj1,A1obj2);”。函数 fune 返回变量 m_A2 和 m_A1 的逻辑与运算结果,因此第 4 处的语句应改为“return obj1.m_A2=TRUEobj2.m_A1=TRUE;”。

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