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

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

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

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

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

    1、国家二级 C+机试(操作题)模拟试卷 287及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6打开考生文件夹下的源程序文件 modi1cpp,但该程序运行时有错,请改正程序中的错误,使程序输出的结果为: 1 5 1 注意:错误的语句在*error*的下面,修改该语句即可。#includeiostreamh*error*enum Sun, Mon, Tue, Wed, Thu, Fri, Sat, *error*MyEnum;struct struct *error* int Fri, int Sun;Void main() int i

    2、=Mon; MyEnum t=Fri; struct str1; str1Fri=Mon; coutiendl; couttendl; coutstr1Friendl;(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.使用 VC6打开考生文件夹下的源程序文件 modi2clap。阅读下列函数说明和代码,实现函数sort(intA,int n),用选择排序法把数组从大到小排序。 提示:选择排序法的思想是: (1)反复从还未排好的那部分线性表中选择出关键字最小的节点; (2)按照从线性表中选择出的顺序排列节点,重新组成线性表; (3)直到未排序的那部分为空,则重新形成的线性表是一

    3、个有序的线性表。 补充函数sort(intA,int n),实现选择排序。 注意:请勿改动主函数。#includeiostreamh#define N 10void sort(int AN,int n)int main() int AN=1,2,10,5,7,19,34,78,-3,8; sort(A,10); for(int i=0;iSizeof(A)sizeof(int);i+) coutAi ; coutendl; return 0;(分数:2.00)_三、综合应用题(总题数:1,分数:2.00)3.使用 VC6打开考生文件夹下的源程序文件 modi3cpp。程序通过继承关系,实现对姓

    4、名的控制。类TestClass1实现对名字访问的接口,TestClass2 实现对名字的设置和输出。 程序输出为: TestClass2Name May 其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。 (1)在类TestClass1中定义接口函数 GetName,为纯虚函数。请在注释*1*后添加适当的语句。(2)函数 GetName2()实现获得名字的缓存,但是只获得读允许操作这个缓存,请在注释*2*后添加适当的语句。 (3)实现 TestClass2的构造函数,请在注释*3*后添加适当的语句。 (4)完成 TestClass2的构造函数,实现对名字的处理。请在注释*4*后添加

    5、适当的语句。 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。#includeiostreamhClass TestClass1public: *1*;class TestClass2:public TestClass1public: Void GetName() cout“TestClass2Name“endl; *2* return m str; *3* int i; for(i=0;stri!=0;i+ m stri = stri; *4* private: char m str32;Void main() TestC2assl*p; TestClass2

    6、 obj1(“Hay“); P=obj1; P-GetName(); coutobj1GetName2()end2; return;(分数:2.00)_国家二级 C+机试(操作题)模拟试卷 287答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6打开考生文件夹下的源程序文件 modi1cpp,但该程序运行时有错,请改正程序中的错误,使程序输出的结果为: 1 5 1 注意:错误的语句在*error*的下面,修改该语句即可。#includeiostreamh*error*enum Sun, Mon, Tue, Wed, Thu, Fri,

    7、Sat, *error*MyEnum;struct struct *error* int Fri, int Sun;Void main() int i=Mon; MyEnum t=Fri; struct str1; str1Fri=Mon; coutiendl; couttendl; coutstr1Friendl;(分数:2.00)_正确答案:(正确答案:(1)enum MyEnum (2); (3)int Fri;)解析:解析:(1)第一标识下声明枚举类型,声明枚举类型的一般形式为:“enum枚举类型名枚举常量列表;”,程序当中把枚举类型名 MyEnum放到枚举声明后面,显然不符合枚举类型

    8、声明格式,因此第 1个标识下应改成“enum MyEnum”。 (2)由(1)的分析可知,第 2个标识下也不符合枚举类型声明格式,应以“:”结束,即第 2个标识下应改为“;”。 (3)第 3标识处声明结构体,结构体定义的一般形式为: struct结构体名 成员列表 变量名列表; 结构体中成员列表中各个元素是不同的变量,变量之间应以分号隔开,而不是以逗号隔开,因此第 3个标识下应改为为“int Fri;”。二、简单应用题(总题数:1,分数:2.00)2.使用 VC6打开考生文件夹下的源程序文件 modi2clap。阅读下列函数说明和代码,实现函数sort(intA,int n),用选择排序法把数

    9、组从大到小排序。 提示:选择排序法的思想是: (1)反复从还未排好的那部分线性表中选择出关键字最小的节点; (2)按照从线性表中选择出的顺序排列节点,重新组成线性表; (3)直到未排序的那部分为空,则重新形成的线性表是一个有序的线性表。 补充函数sort(intA,int n),实现选择排序。 注意:请勿改动主函数。#includeiostreamh#define N 10void sort(int AN,int n)int main() int AN=1,2,10,5,7,19,34,78,-3,8; sort(A,10); for(int i=0;iSizeof(A)sizeof(int)

    10、;i+) coutAi ; coutendl; return 0;(分数:2.00)_正确答案:(正确答案:int i,j; for (i=0;in-1;i+) for (j=0;jn-1-i;j+) if(AjAj+1) 如果前面的数比后面的大则进行交换 int t=Aj;做交换 Aj=Aj+1; Aj+1 =t; )解析:解析:(1)数组 AN中有 n个数,进行 n-1趟比较,在每一趟比较中两两比较的次数逐渐减少,比如若有 6个数 9,8,5,4,2,0。第一次将 8和 9对调,第二次将第 2和第 3个数(9 和 5)对调,如此共进行 5次,得到 8-5-4-2-09 的顺序,可以看到:最

    11、大的数 9已“沉底”,成为最下面一个数,而小的数“上升”。最小的数 0已向上“浮起”一个位置。经第一趟(共 5次)后,已得到最大的数。然后进行第二趟比较,对余下的前面 5个数按上法进行比较,经过 4次比较,得到次大的数 8。如此进行下去。可以推知,6 个数要比较 5趟。在第一趟中要进行两两比较 5次,在第二趟中比 4次,第 5趟比 1次。因此设置两层循环,外层循环变量 i从 0变化大到 n-1,内层循环变量 i从 0到 n-i,在内层循环体内,比较相邻两数,如果前面比后面的大则交换。 (2)在内层循环体内,如果前面的元素比后面的元素大,则用一个临时变量记录前面的第 i个元素,然后将第 j+1个

    12、元素赋值给第 i个元素,临时变量值赋给第 i+1个元素,如此完成两个元素的交换。三、综合应用题(总题数:1,分数:2.00)3.使用 VC6打开考生文件夹下的源程序文件 modi3cpp。程序通过继承关系,实现对姓名的控制。类TestClass1实现对名字访问的接口,TestClass2 实现对名字的设置和输出。 程序输出为: TestClass2Name May 其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。 (1)在类TestClass1中定义接口函数 GetName,为纯虚函数。请在注释*1*后添加适当的语句。(2)函数 GetName2()实现获得名字的缓存,但是只获得

    13、读允许操作这个缓存,请在注释*2*后添加适当的语句。 (3)实现 TestClass2的构造函数,请在注释*3*后添加适当的语句。 (4)完成 TestClass2的构造函数,实现对名字的处理。请在注释*4*后添加适当的语句。 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。#includeiostreamhClass TestClass1public: *1*;class TestClass2:public TestClass1public: Void GetName() cout“TestClass2Name“endl; *2* return m str;

    14、*3* int i; for(i=0;stri!=0;i+ m stri = stri; *4* private: char m str32;Void main() TestC2assl*p; TestClass2 obj1(“Hay“); P=obj1; P-GetName(); coutobj1GetName2()end2; return;(分数:2.00)_正确答案:(正确答案:(1)添加语句:virtual void GetName()=0; (2)添加语句:const char*GetName2() (3)添加语句:TestClass2(char*str) (4)添加语句:m str

    15、i=0;)解析:解析:(1)题目 1要求“在类 TestClass1中定义接口函数 GetName,为纯虚函数”。在 C+中,在基类中用 virtual声明成员函数为虚函数。纯虚函数是在声明虚函数时被“初始化”为 0的函数,即“virtualvoid GetName()=0:”。 (2)题目 2要求“函数 GetName20实现获得名字的缓存,但是只获得读允许操作这个缓存”。只能引用数据成员,而不能修改,那么使用常成员函数。一般形式为,const 函数类型函数名,即“const char*GetName2()”。 (3)题目 3要求“实现 TestClass2的构造函数”。TestClass2的构造函数与类 TestClass2名应该相同,而且第三个标识下的大括弧中是对字符数组 str的操作,所以类 TestClass2的构造函数中的参数为 str,即这里补全为“TestClass2(char*str)”。 (4)题目 4要求“完成 TestClass2的构造函数,实现对名字的处理”,补全类 TestClass2的构造函数,构造函数中的名字变量 s仃对应于类 TestClass中的成员变量 m str,所以这里补全变量赋值操作“m_stri=0;”。


    注意事项

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




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

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

    收起
    展开