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

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

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

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

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

    1、国家二级 C+机试(操作题)模拟试卷 486及答案与解析 一、基本操作题 1 请打开考生文件夹下的解决方案文件 proj1,程序中位于每个 “ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应为: Name: Smith Age: 21 ID: 99999 CourseNum: 12 Record: 970 注意:只修改每个 “ ERROR*found*”下的那一行,不要改动程序中的其他内容。 #include iostream using namespace std; class StudentInfo protected: ERROR*found* char

    2、 Name; int Age; int ID; int CourseNum; float Record; public: StudentInfo(char*name, intAge, int ID, int courseNum, float record); ERROR*found* VOid StudentInfo( ) float AVerageRecord( ) return Record CourseNum; void show( )const cout “Name: “ Name “Age: “ Age “ID: “ ID “CourSeNum: “ CourSeNum “ReCOr

    3、d: “ Re-cord endl; ; ERROR*found* StudentInfo StudentInfo(char*Name, int Age, int ID, intCourseNum, float Record) Name=name; Age=age; this- ID=ID; CourSeNum=courSeNum; Record=record; int main( ) StudentInfo st(“Smith“, 21, 99999, 12, 970); st show( ); return0; 二、简单应用题 2 请打开考生文件夹下的解决方案文件 proj2,其中有矩阵基

    4、类 MatrixBase、矩阵类 Matrix和单位阵 UnitMatrix的定义,还有 main函数的定义。请 在横线处填写适当的代码并删除横线,以实现上述类定义。此程序的正确输出结果应为: 1 2 3 4 5 2 3 4 5 6 3 4 5 6 7 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0 1 注意:只能在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动 “ *found*”。 #include iostream using namespace std; 矩阵基础类,一个抽象类

    5、 class MatrixBase int rows, cols; public: MatrixBase(int rows, int cols): rows(rows), cols(cols) int getRows( )constreturnroows矩阵行数 int getCols( )constreturncols; 矩阵列数 virtual double getElement(intr, int c)const=0;取第 i个元素的值 void show( )const 分行显示矩阵中所 有元素 for(int i=0; i rows; i+) cout endl; for(int j

    6、=0; J cols; j+) *found* cout _ “ “; ); 矩阵类 class Matrix: public MatrixBase double*val; public: *found* Matrix(int rows, int cols, double m =NULL): _ *found* val=_; for(int i=0; i rows*cols; i+) vali=(m=NULL?0 0: mi); Matrix( )delete val; ) double getElement(int r, intc)constreturn valr*getCols( )+c;

    7、 ; 单位阵 (主对角线元素都是 1,其余元素都是 0的方阵 )类 class UnitMatrix: public MatrixBase public: UnitMatrix(int rows): MatrixBase(rows, rows) 单位阵行数列数相同 double getElement(int r, int c) const *found* if(_)return1 0; return0 0; ; int main( ) MatrixBase*m; double d 5=1, 2, 3, 4, 5), 2, 3, 4, 5, 6, 3, 4, 5, 6, 7; m=new Mat

    8、rix(3, 5, (double*)d); m- show( ); delete m; cout endl; m=new UnitMatrix(6); m- show( ); delete m; return0; 三、综合应用题 3 请打开考生文件夹下的解决方案文件 proj3,其中定义了用于表示特定数制的数的模板类 Number和表示一天中的时间的类 TimeOfDay;程序应当显示: 01: 02: 03 004 06: 04: 06 021 但程序中有缺失部分,请按照以下的提示,把缺失部分补 充完整: (1)在 “ *1* *found*”的下方是一个定义数据成员 seconds的语句

    9、,seconds用来表示 “秒 ”。 (2)在 “ *2* *found*”的下方是函数 advanceSeconds中的一个语句,它使时间前进 k秒。 (3)在 “ *3* *found*”的下方是函数 advance中的一个语句,它确定增加k后 n的当前值和进位,并返回进位。例如,若 n的当前值是表示时间的 55分,增加 10分钟后当前值即变为 5分,进位为 1(即 1小时 )。 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动 “*found*”。填写的内容必须在一行中完成,否则评分将产生错误。 proj3 cpp #include iostream #incl

    10、ude iomanip using namespace std; template intbase数制为 base的数 class Number int n;存放数的当前值 public: Number(int i): n(i) i必须小于 base int advance(int k);当前值增加 k 个单位 int value( )constreturn n; 返回数的当前值 , class TimeOfDay public: Number 24 hours;小时 (0 23) Number 60 minutes;分 (0 59) *1* *found* _;秒 (0 59) Number

    11、 1000 milliseconds; 毫秒 (0 999) TimeOfDay(int h=0, intm=0, int s=0, int milli=0) : hours(h), minuteS(m), seconds(S), milliseconds(milli) void advanceMillis(int k)advanceSeconds (milliseconds advance(k); 前进 k毫秒 void advanceSeconds(int k)前进 k秒 *2* *found* _; void advanceMinuteS(int k)advanceHour(minute

    12、s advance(k); 前进 k分钟 Vvoid advanceHour(int k)hours advance(k); 前进 k小时 void show( )const 按 “小时:分:秒毫秒 ”的格式显示时间 int c=cout fill(0); 将填充字符设置为 0 cout Setw(2) hours valme( ) : 显示小时 setw(2) minutes value( ) : 显示分 Setw(2) Seconds value( ) 显示秒 Setw(3) milliseconds value( );显示毫秒 cout fill(c);恢复原来的 填充字符 ; temp

    13、late int base int Number base: advance(int k) n+=k;增加 k个单位 int s=0; s用来累计进位 *3* *found* while(n =base)_ n到达或超过 base即进位 return s;返回进位 int msin( ) TimeOfDay time(1, 2, 3, 4); 初始时间: 1小时 2分 3秒 4毫秒 time show( );显示时间 time advanceHour(5);前进 5小时 time advanceSeconds(122);前进 122秒 (2分零 2秒 ) time advanceMilliS(

    14、1017);前进 1017毫秒 (1秒零 17毫秒 ) cout endl: time show( );显示时间 cout endl; return0; 国家二级 C+机试(操作题)模拟 试卷 486答案与解析 一、基本操作题 1 【正确答案】 (1)char*Name; (2) StudentInfo( ) (3)Studentlnfo: Studentlnfo(char*name, int age, int ID, int courseNum, float record) 【试题解析】 (1)主要考查考生对动态数组的掌握,由题目可知 Name应该指向一个动态数组,而不是一个有效 char型

    15、字符,因此要定义成 char型指针。 (2)主要考查考生对析构函数的掌握,析构函数不需要函数返回类型, 应把 void去掉。 (3)主要考查考生对构造函数定义的掌握,构造函数也要使用作用域符号 “: ”。 二、简单应用题 2 【正确答案】 (1)getElement(i, j) (2)MatrixBase(rows, cols) (3)new doublerows*cols (4)r=c 【试题解析】 (1)主要考查考生对纯虚函数的掌握,函数功能是分行显示矩阵中所有元素。因此在这里要输出行为 i、列为 j的元素,使用纯虚函数getElement(i, j)实现,输出语句为 cout getEl

    16、emenl, (i, j) “ “;。 (2)主要考查考生对派生类的构造函数的掌握,派生类的构造函数使用成员列表初始化法,先对基类初始化。 (3)主要考查考生对动态数组的掌握, val是 double型指针,要给 val赋值,就要先给它分配空间,应使用 new来完成。 (4)主要考查考生对成员函数的掌握,因为要输出单位矩阵,只有满足条件 r=c的元素为 1 0,所以填写语句 if(r=c)return1 0;。 三、综合应用题 3 【正确答案】 (1)Number 60 seconds (2)advanceMinutes(seconds advance(k) (3)s+; n-=base; 【

    17、试题解析】 (1)主要考查考生对模板类的掌握,这里是一个定义数据成员seconds的语句, seconds用来表示 “秒 ”,可以根据小时、分、毫秒的定义形式填写,即 Number 60 seconds。 (2)主要考查考生对成员函数的掌握,此处是函数 advanceSeconds中的一条语句,它使时间前进 k秒。将前后语句进行对比,可以知道应该填入 语句advanceMinutes(seconds advance(k)。 (3)考查 while循环语句,此处是函数 advance中的一条语句,它确定增加 k后 n的当前值和进位,并返回进位。变量 s表示累加进位,当 n到达或超过 base即进位,进位时 s要自加 1,因此为 s+; n-=base。


    注意事项

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




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

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

    收起
    展开