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

上传人:inwarn120 文档编号:497564 上传时间:2018-11-28 格式:DOC 页数:8 大小:36.50KB
下载 相关 举报
[计算机类试卷]国家二级C++机试(操作题)模拟试卷469及答案与解析.doc_第1页
第1页 / 共8页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷469及答案与解析.doc_第2页
第2页 / 共8页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷469及答案与解析.doc_第3页
第3页 / 共8页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷469及答案与解析.doc_第4页
第4页 / 共8页
[计算机类试卷]国家二级C++机试(操作题)模拟试卷469及答案与解析.doc_第5页
第5页 / 共8页
点击查看更多>>
资源描述

1、国家二级 C+机试(操作题)模拟试卷 469及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 proj1下的工程 proj1,该工程中包含程序文件 main cpp,其中有类 Foo和主函数 main的定义。程序中位于每个 “ ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应该是: X=a Y=42 注意:只修改每个 “ ERROR*found*”下的那一行,不要改动程序中的其他内容 。 #include using namespace std; class Foo public: Foo(char x)x =x; char g

2、etX()constreturn x; public: static int y_; private: char x; ; ERROR *found* int Foo y_=42; int main(int argc, char*argV ) ERROR*found* Foo f; ERROR *found* tout; using namespace std; 矩阵基础类,一个抽象类 class MatrixBase int rows, cols; public: MatrixBase(int rows, int cols): rows(rows), cols(cols) int getRo

3、ws()const return rows; 矩阵行数 int getCols()constreturn cols; 矩阵列数 virtual double getElement(int r, int c)const=0;取第 i个元素的值 void show()const 分行显示矩阵中所有元素 for(int i=0 ; ishow(); delete m; toutshow(); delete m; return 0; 三、综合应用题 3 请使用 VC6或使用【答题】 菜单打开考生目录 proj3下的工程文件 proj3,其中定义了用于表示特定数制的数的模板类 Number和表示一天中的

4、时间的类TimeOfDay;程序应当显示: 01: 02: 03 004 06: 04: 06 021 但程序中有缺失部分,请按照以下的提示,把缺失部分补充完整: (1)在 “ *1* *found*”的下方是一个定义数据成员 seconds的语句,seconds用来表示 “秒 ”。 (2)在 “ *2* *found*”的下方是函数 advanceSeconds中的一个语句,它使时间前进 k秒。 (3)在 “ *3* *found*”的下方是函数 advance中的一个语句,它确定增加 k后 n的当前值和进位,并返回进位。例如,若 n的当前值是表示时间的 55分,增加 10分钟后当前值即变为

5、 5分,进位为 1(即 1小时 )。 注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动 “*found*”。填写的内容必须在一行中完成,否则评分将产生错误。 proj3 cpp #include #include using namespace std; template 数制为 base的数 class Number int n; 存放数的当前值 public: Number(int i)-n(i) i必须小于 base int advance(int k);当前值增加 k个单位 int value()constreturn n; 返回数的当前值 ; class T

6、imeOfDay public: Numberhours; 小时 (0 23) Numberminutes; 分 (0 59) *1* *found* _;秒 (0 59) Numbermilliseconds; 毫秒 (0 999) TimeOfDay(int h=0, int m=0, int s=0, int milli=0) : hours(h), minutes(m), seconds(s), milliseconds(milli) void advanceMillis(int k) advanceSeconds(milliseconds advance(k); 前进 k毫秒 voi

7、d advanceSeconds(int k) 前进 k秒 *2* *found* _; void advanceMinutes(int k) advanceHour(minutes advance (k); 前进 k分钟 void advanceHour(int k) hours advance(k); 前进 k小时 void show()const 按 “小时:分:秒毫秒 ”的格式显示时间 int c=cout fill(0); 将填充字符设置为 0 cout int Number: advance (int k) n+=k; 增加 k个单位 int s=0; s用来累计进位 *3* *f

8、ound* while(n=base)_ n到达或超过 base即进位 return s;返回进位 int main() TimeOfDay time(1, 2, 3, 4); 初始时间: 1小时 2分 3秒 4毫秒 time show(); 显示时间 time advanceHour(5); 前进 5小时 time advanceSeconds(122); 前进 122秒 (2分零 2秒 ) time advanceMilliS(1017); 前进 1017毫秒 (1秒零 17毫秒 ) coutseconds (2)advanceMinutes(seconds advance(k) (3)s

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

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 考试资料 > 职业资格

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