ImageVerifierCode 换一换
格式:DOC , 页数:7 ,大小:37KB ,
资源ID:497580      下载积分:2000 积分
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝扫码支付 微信扫码支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【http://www.mydoc123.com/d-497580.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

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

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

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

2、return x_ public: static int y_; private: char x_; ; ERROR*found* int; Foo y_=42; int main(int argo, char*argV ) ERROR*found* Foo f; ERROR*found* tout: “X=“ f X endl; cout; “Y=“ f y_ endl; return0; 二、简单应用题 2 请打开考生文件夹下的解决方案文件 proj2,此工程中声明的 Array是一个表示数组的类。一个 Array对象可以包含多个整型元素。 Array的成员说明如下: 成员函数 add用于

3、向数组的末尾添加一个元素; 成员函数 get用于获取数组中指定位置的元素; 数据成员 a表示实际用于存储数据的整型数组; 数据成员 size表示数组的容量,数组中的元素个数最多不能超过 size; 数据成 员 num表示当前数组中的元素个数。 SortedArray是 A11ray的派生类,表示有序数组。 SortedArray重新定义了 Array中的 add函数,以确保有序数组中的元素始终按照升序排列。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为: 10, 9, 8, 7, 6, 5, 4, 3, 2, 1, 1, 2, 3, 4, 5, 6,

4、 7, 8, 9, 10, 注意:只在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动 “ *found*”。 #include iostream using namespace std; class Array public: Array(unsigned int s) Size=s; num=0; a=new ints; virtual Array( )delete a; virtual void add(int e) if(num Size) *found* _ num+; int get(unsigned int i)const if(i size) return ai

5、; return0; protected; int*a; unsigned int Size, num; ; class SortedArray: public Arraypublic: *found* SortedArray(unsigned int s) : _ virtual void add(int e) if(num =size) return; int i=0, j; while(i num) if(e ai) for(j=num; j i; j-) *found* _; *found* _; break; i+; if(i=num) ai=e; num+; ; void fun(

6、Array&a) int i; for(i=10; i =1; i-) a add(i); for(i=0; i 10; i+) cout a get(i) “, “; cout end1; int main( ) Array a(10); fun(a); SortedArray sa(10); fun(sa); return0; 三、综合应用题 3 请打开考生文件夹下的解决方案文件 proj3,其中定义的 Matrix是一个用于表示矩阵的类。成员函数 max_value的功能是求出所有矩阵元素中的最大值。例如,若有 33矩阵 则调用 max_value函数,返回值为 3。请编写成员函数max

7、_value。要求:补充编制的内容写在 “ *333*”与 “*666*”之间,不得修改程序的其他部分。注意:程序最后将结果输出到文件 out dat中。输出函数 writeToFile已经编译为 Obj文件,并且在本程序中调用。 Matfix h#include iostream #include iomanip using namespace std; const int M=18; conSt int N=18; Class Matrixint arrayMN; public:Matrix( )int getElement(int i, int j)constreturn arrayij

8、; VOid setElement(int i,int j, int value)arrayij=value; int max value( )const; void show(const char*s)constcout endl s; for(int i=0; i M; i+)(cout endl; for(int j=0; j N; j+)cout setw(4) arrayij; ; void readFromFile(const char*, Matrix&); void writeToFile(char*, const Matrix&);main cpp#include“Matri

9、x h“#include fstream void readFromFile(const char*f,Matrix&m)ifstream infile(f); if(infile fail( )cerr “打开输入文件失败 !“;return; int k; for(int i=0; i M; i+)for(int j=0; j N; j+)infile k;m setElement(i, j, k); int Matrix: max_value( )const*333* *666*int main( )Matrix m; readFromFile(“ “, m); m show(“Matr

10、ix: “); cout endl “最大元素: “ m maxvalue( ) endl; writeToFile(“ “, m); return0; 国家二级 C+机试(操作题)模拟试卷 483答案与解析 一、基本操作题 1 【正确答案】 (1)int Foo: y_=42; (2)Foo f(a); (3)cout “X=“ f getX( ) endl; 【试题解析】 (1)主要考查考生对静态成员的掌握,因为静态整型变量 y_是 Foo类的公有成员,所以给 y_赋值时要加上 “Foo: ”,即 int Foo: y_=42;。 (2)主要考查考生对构造函数的掌握,题目要求程序输出: X

11、=a Y=42 可以知道,在给 Foo类的 f声明时要同时初始化为字符 a,即语句 Foo f(a);。 (3)主要考查考生对成员函数 的掌握,因为 x是类 Foo的私有成员,所以不能在main函数中直接调用,要通过公有成员函数 getX( )调用。 二、简单应用题 2 【正确答案】 (1)aBum=e; (2)Array(S) (3)aj=aj-1 (4)ai=e 【试题解析】 (1)考查的是虚函数 virtual void add(inte)的定义,即添加一个整型数 e到 anum中。 (2)主要考查的是 Array类的派生类 SortedArray类的构造函数的定义,定义之前要对基础类初

12、始化。 (3)因为 SortedArray类是排序类,所以数组 a中的元素要从小到大排序。在 if(eai)条件下,要把 i后的元素逐个往后移一位,因此此处为 aj=aj-1。 (4)主要考查虚函数 virtual void add(int e)在派生类 SortedArray类中的定义,把插入的数据放在数组 a的第 i+1个位置,即 ai=e;。 三、综合应用题 3 【正确答案】 int temp=0;定义整数变量 temp,并赋值为零 for(int i=0; i M; i+)遍历矩阵的行 for(int j=0; j N; j+)遍历短阵的列 if(temp arrayij)如果 temp小于 arrayij temp=arrayij;把 arrayij赋值给 temp return temp;返回 temp 【试题解析】 主要考查考生对二维数组的掌握,题目要求成员函数 max_value的功能是求出所有矩阵元素中的最大值。因此只要逐个元素比较即可,下标 i和 j作为矩阵行和列的标记,使用双层 for循环来遍历数组中的所有元素。

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