欢迎来到麦多课文档分享! | 帮助中心 海量文档,免费浏览,给你所需,享你所想!
麦多课文档分享
全部分类
  • 标准规范>
  • 教学课件>
  • 考试资料>
  • 办公文档>
  • 学术论文>
  • 行业资料>
  • 易语言源码>
  • ImageVerifierCode 换一换
    首页 麦多课文档分享 > 资源分类 > DOC文档下载
    分享到微信 分享到微博 分享到QQ空间

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

    • 资源ID:1331910       资源大小:33.50KB        全文页数:3页
    • 资源格式: DOC        下载积分:5000积分
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    二维码
    微信扫一扫登录
    下载资源需要5000积分(如需开发票,请勿充值!)
    邮箱/手机:
    温馨提示:
    如需开发票,请勿充值!快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如需开发票,请勿充值!如填写123,账号就是123,密码也是123。
    支付方式: 支付宝扫码支付    微信扫码支付   
    验证码:   换一换

    加入VIP,交流精品资源
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

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

    1、国家二级 C+机试(操作题)模拟试卷 428及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6打开考生文件夹下的源程序文件 modilcpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为: Max is 7 提示:max()数实现找出两个数中的最大值,并作为函数值返回。 注意:错误的语句在 *error*的下面,修改该语句即可。#includeiostreamusing namespace std; *error*int max(int a,int b) if(ab) int t=a; a=b; b=t;

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

    3、会变成有序的,而且是由大到小的顺序。 注意:不能修改程序的其他部分,并且不能删除其他的部分,也不能修改程序的结构。#includeiostreamh#define N 10void sort(int AN,int n)int main() int AN=5,7,4,6,10,13,78,4,9,20; sort(A,10); for(int i=0;isizeof(A)sizeof(int);i+) coutAi ; coutend1; return 0; (分数:2.00)_三、综合应用题(总题数:1,分数:2.00)3.使用 VC6打开考生文件夹下的源程序文件 modi3cpp。其中定义的

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

    5、eamh*1*#define FALSE 0*2*Class A2 private: bool m_A2; friend bool func(A2&obj1,A1&obj2);public: A2() m_A2=FALSE; public: void setA2(bool n) m_A2=n; ; class A1 private: bool m A1; *3*public: A1() m_A1=TRUE; public: void setA1(bool n) m_A1=n; ;bool func(A2&obj1,A1&obj2) *4* return int main() A2 obj0;

    6、A1 obj1; coutfunc(obj0,obj1)end1; obj0setA2(TRUE); obj1setA1(TRUE); coutfunc(obj0,obj1)end1; return 0; (分数:2.00)_国家二级 C+机试(操作题)模拟试卷 428答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6打开考生文件夹下的源程序文件 modilcpp,该程序运行时有错,请改正其中的错误,使程序正常运行,并使程序输出的结果为: Max is 7 提示:max()数实现找出两个数中的最大值,并作为函数值返回。 注意:错误的语句

    7、在 *error*的下面,修改该语句即可。#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;(分数:2.00)_正确答案:(正确答案:(1)int max(int&a,int&b) (2)max(m,n);)解析:解析:(1)max 函数采用的是传送引用方式传递参数,因此第 1个标识下应该为 int

    8、 max(int&a,int ab)。 (2)调用 max时,传递引用时直接使用变量名即可,第 2个标识下应改为“max(m,n)”。二、简单应用题(总题数:1,分数:2.00)2.使用 VC6打开考生文件夹下的源程序文件 modi2cpp。阅读下列函数说明和代码,完成空出部分的程序。实现函数 sort(intA,int n),用冒泡法将数组排序。 提示:所谓冒泡法,就是每次把相邻的两个数交换,较大的数交换到后面。这样下标从 0到 n-1的数与其后面相邻的数交换,可以把最大的数交换到数组的末端。进行 n次下标从 0到 n-1的交换,则数组则会变成有序的,而且是由大到小的顺序。 注意:不能修改程

    9、序的其他部分,并且不能删除其他的部分,也不能修改程序的结构。#includeiostreamh#define N 10void sort(int AN,int n)int main() int AN=5,7,4,6,10,13,78,4,9,20; sort(A,10); for(int i=0;isizeof(A)sizeof(int);i+) coutAi ; coutend1; return 0; (分数:2.00)_正确答案:(正确答案:int i,j,k,t; for( i=0;in-1;i+) for(k=i,j=i+1;jn;j+) if(AkAj)如果前面的比后面的小则需要交换

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

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

    12、l fune(A2&a,A1&b),请在注释*3*后添加适当的语句。 (4)实现函数 bool func(A2&obj1,Al&obj2)功能,检查两个类的值都为 TRUE,则返回 TRUE,请在注释*4*后添加适当的语句。 注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。#includeiostreamh*1*#define FALSE 0*2*Class A2 private: bool m_A2; friend bool func(A2&obj1,A1&obj2);public: A2() m_A2=FALSE; public: void setA2(bool n) m_A2

    13、=n; ; class A1 private: bool m A1; *3*public: A1() m_A1=TRUE; public: void setA1(bool n) m_A1=n; ;bool func(A2&obj1,A1&obj2) *4* return int main() A2 obj0; A1 obj1; coutfunc(obj0,obj1)end1; obj0setA2(TRUE); obj1setA1(TRUE); coutfunc(obj0,obj1)end1; return 0; (分数:2.00)_正确答案:(正确答案:(1)添加语句:#define TRUE

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


    注意事项

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




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

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

    收起
    展开