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

    [计算机类试卷]国家二级C++机试(操作题)模拟试卷492及答案与解析.doc

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

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

    [计算机类试卷]国家二级C++机试(操作题)模拟试卷492及答案与解析.doc

    1、国家二级 C+机试(操作题)模拟试卷 492及答案与解析 一、基本操作题 1 请打开考生文件夹下的解决方案文件 proj1,该工程中包含程序文件main cpp,其中有类 Clock(“时钟 ”)的定义和主函数 main的定义。程序中位于每个 “ ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应为: Initial times are 0 d: 0 h: 0 m: 59s After one second times are 0 d: 0 h: 1 m: 0S 注意:只修改每个 “ ERROR*found*”下的那一行,不要改动程序中的其他内容。 #inclu

    2、de iostream using namespace std; class Clock public: Clock(unsigned long i=0); void set(unsigned long i=0); void print( )const; void tick( );时间前进一秒 Clock operator+( ); private: uns igned long total_sec, seconds, fminutes, hours, days; ; Clock: Clock(unsigned long i) : total sec(i), seconds(i 60), mi

    3、nutes(i 60) 60), hours(i 3600) 24), days(i 86400) void Clock: set(unsigned long i) total sec=i; seconds=i 60; minutes=(i 60) 60; hours=(i 3600) 60; days=i 86400; ERROR*found* voidClock: print( ) cout days “d: “ hours “h: “ minutes “m: “ seconds “s“ endl; void Clock: tick( ) ERROR*found* set(total_se

    4、c+); Clock Clock: operator+( ) tick( ); ERROR*found* return this; int main( ) Clock ck(59); tout “Initial times are“ endl; ck print( ); +ck; tout “After One second times are“ endl; ck print( ); return0; 二、简单应用题 2 请打开考生文件夹下的解决方案文件 proj2,此工程包含一个源程序文件proj2 cpp。其中定义了 Score类。 Score是一个用于管理考试成绩的类。其中 ,数据成员

    5、_s指向存储成绩的数组, _n表示成绩的个数;成员函数 Sort使用冒泡排序法将全部成绩按升序进行排列。 请在程序中的横线处填写适当的代码,然后删除横线,以实现 Score类的成员函数Sort。 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动 “ *found*”。 proj2 cpp #include iostream #include cstdlib #include ctime using namespace std; class score public: Score(double*s, intn): _s(s), _n(n) double GetScore

    6、(int i)COBst return_si; void sort( ); private: double*_s; int_n; ; void Score: Sort( ) *found* for(int i=0; i _n-1; _) *found* for(int j=_; j i; j-) if(_sj _sj-1) 交换 _sj和 _sj-1 double t=_sj; *found* _; *found* _; int main( ) conSt int NUN=10; double sNUN; stand(time(0); for(int i=0; i NUN; i+) si=do

    7、uble(rand( ) RAND MAX*100; Score ss(s, NUM); ss Sort( ); for(int j=0; j NUM; j+) cout ss GetScore(j) endl; return0; 三、综合应用题 3 请打开考生文件夹下的解决方案文件 proj3,其中声明的 DataList类,是一个用于表示数据表的类。 sort成员函数的功能是将当前数据表中的元素升序排列。请编写这个 sort函数。程序的正确输出应为: 排序前: 7, 1, 3, 11, 6, 9, 12, 10, 8, 4, 5, 2 排序后: 1, 2, 3, 4, 5, 6, 7, 8

    8、, 9, 10, 11, 12 要求: 补充编制的内容写在 “ *333*”与 “ *666*”两行之间。不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out dat中。输出函数 writeToFile已经编译为obj文件,并且在本程序调用。 DataList h #include iostream using namespace std; class DataList数据表类 int len; double*d; public: DataList(int len, double data =NULL); DataList( )delete d; int length( )cons

    9、treturnlen; 数据表长度 (即数据元素的个数 ) double getElement(int i)constreturn di; void sort( );数据表排序 void show( )const;显示数据表 ; void writeToFile(char*, constDataList&); main cpp #include“DataList h“ DataList: DataList(intlen, double data ): len(len) d=new doublelen; for(int i=0; i len; i+) di=(data=NULL?0 0: dat

    10、ai); void DataList: sort( )数据表排序 *333* *666* void DataList: show( )const显示数据表 for(int i=0; i len-1; i+)tout di “, “; tout dlen-1 endl; int main( ) double s =7, 1, 3, 11, 6, 9, 12, 10, 8, 4, 5, 2; DataList list(12, s); cout “排序前: “; list show( ); liSt sort( ); cout endl “排序后: “; list show( ); writeTo

    11、File(“ “, liSt); return0; 国家二级 C+机试(操作题)模拟试卷 492答案与解析 一、基本操作题 1 【正确答案】 (1)void Clock: print( )const (2)set(+total_see); (3)return*this; 【试题解析】 (1)主要考查考生对成员函数的掌握,由 Clock类中对函数 print的声明 void print( )const;可知,在定义 print函数时少了 const。 (2)主要考查考生对 +操作的掌握,根据函数要求,时间要先前进一秒,再调用函数 set,因此 total_sec+应改为 +total_sec.

    12、(3)主要考查考生对 this指针的掌握,函数要求返回值 Clock,即返回一个类,而不是指针,因此使用 *this。 二、简单应用题 2 【正确答案】 (1)i+ (2)_n-1 (3)_sj=_sj-1 (4)_sj-1=t 【试题解析】 (1)主要考查 for循环语句,从题目要求可知循环变量 i要从 0到 _n-2,因此 i要递增操作,即 i+。 (2)主要考查考生对冒泡排序的掌握,这里要求从后往前扫描,比较相邻两个元素,若后者小则交换,因此在这里下标 j要从最后开始,即 int_i=_n-1。 (3)考查交换算法,在 if语句中 _sj _sj-1满足条件,则实现交换。因为已经把_sj

    13、的值赋给了中间变量 t,所以这里要把 _sj-1的值赋给 _sj,即 _sj=_sj-1;。 (4)考查交换算法,这里只需把中间变量 t中的值赋给 _sj-1即可。 三、综合应用题 3 【正确答案】 for(int i=0; 1 len; +i)从头遍历数组 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 【试题解析】 本题使用最简单的冒泡排序算法,首先明确要排序的动态数组 d,其长度为 len,在此可以使用两个下标 i和 j相比较,当 di dj时,数组内的值利用中间变量 temp进行交换。


    注意事项

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




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

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

    收起
    展开