1、国家二级 C+机试(操作题)-试卷 163 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj1 下的工程 proj1,该工程中含有一个源程序文件proj1cpp。其中位于每个注释“ERROR*found*”之后的一行语句有错误。请改正这些错误,使程序的输出结果为:1 2 3 4 5 6 7 8 9 10 注意:只能修改注释“ERROR*found*”的下一行语句,不要改动程序中的其他内容。projlcpp#includeiostreamusing namespace std;class
2、MyClass public: MyClass(int len) array=new intlen; arraySize=len; for(int i=0;iarraySize;i+)arrayi=i+1;MyClass()ERROR*found* delete arrayi;void Print()constfor(int i=0;iarraySize;i+)ERROR*found* cinarrayi”; coutendl;private: int*array; int arraySize;,int main()ERROR* found*MyClass obj;objPrint();ret
3、urn 0;(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.请使用 VC6 或使用【答题】菜单打开考生文件夹 proj2 下的工程 proj2,此工程中声明的 Array 是一个表示数组的类。一个 Array 对象可以包含多个整型元素。Array 的成员说明如下:成员函数 add 用于向数组的末尾添加一个元素;成员函数 get 用于获取数组中指定位置的元素;数据成员 a 表示实际用于存储数据的整型数组;数据成员 size 表示数组的容量,数组中的元素个数最多不能超过 size; 数据成员 num表示当前数组中的元素个数。 $ortedArray 是 Array 的派生类,表
4、示有序数组。SortedArray 重新定义了Array 中的 add 函数,以确保有序数组中的元素始终按照升序排列。请在程序中的横线处填写适当的代码,然后删除横线,以实现上述类定义。此程序的正确输出结果应为:10,9,8,7,6,5,4,3,2,1,l,2,3,4,5,6,7,8,9,10,注意:只在横线处填写适当的代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。#includeiostreamusing namespace std;class Arraypublic: Array(unsigned int S) size=S;num=0;a=new ints;virtu
5、alArray()deletea; )virtual void add(int e)if(numsize)*found* num+; ) int get(unsigned int i)const if(iSize)return ai;return 0;protected: int*a; unsigned int size,num; ; class SortedArray:public Array public: * found* SortedArray(unsigned int s) :_ virtual void add(int e) if(num=size)return;int i=0,j
6、;while(inum)if(eai)for(j=num;ji;j)*found* ;: *found* : break;i+;if(i=num)ai=e;num+; ; void fun(Array class SortedArray:public Array public: * found* SortedArray(unsigned int s) :_ virtual void add(int e) if(num=size)return;int i=0,j;while(inum)if(eai)for(j=num;ji;j)*found* ;: *found* : break;i+;if(i
7、=num)ai=e;num+; ; void fun(Array&a) int i; for(i=10;i=1;i一)aadd(i);for(i=0;i1 0;i+)coutaget(i)“,”;coutendl; int main() Array a(10); fun(a); SortedArray sa(10); fun(sa); return 0; (分数:2.00)_正确答案:(正确答案:(1)anum=e; (2)Array(s) (3)aj =aj1 (4)ai =e)解析:解析:本题考查数组类 Array 及 Array 的派生类 SortedArray,其知识点涉及构造函数、析
8、构函数、虚函数和动态数组。一般考到函数时,首先要看函数名,通过函数名称能大概知道该函数的功能,比如Array 类中的 virtual void add(int e)函数,看到这个函数我们能得到如下信息。 (1)有关键字virtual,说明该函数是虚函数,在 Array 类的派生类里肯定会有对 add 函数的定义。 (2)有关键字void,说明此函数没有返回值。 (3)add 的意思是添加,它的形参是 int e,那么我们大概可以猜到该函数的功能是把整型数值 e 添加到数组 a 中。 【解题思路】 (1)考查的是虚函数 virtual void add(int e)的定义,即添加一个整型数 e
9、到 anum中。 (2)主要考查的是 Array 类的派生类 SortedArray 类的构造函数的定义,定义之前要对基础类初始化。 (3)因为 SortedArray 类是排序类,所以数组 a 中的元素要从小到大排序。在 if(e三、综合应用题(总题数:1,分数:2.00)3.请使用 VC6 或使用【答题】菜单打开考生目录 proj3 下的工程文件 proj3,此工程包含一个源程序文件proj3cpp,其中定义了用于表示二维向量的类 MyVector;程序应当显示(6,8)。但程序中有缺失部分,请按照以下提示,把缺失部分补充完整:(1)在“*found*”的下方是构造函数的定义,它用参数提供
10、的坐标对 x 和 y 进行初始化。(2)在“*2*found*”的下方是减法运算符函数定义中的一条语句。两个二维向量相减生成另一个二维向量:其 x 坐标等于两向量 x 坐标之差,其 y 坐标等于两向量 Y 坐标之差。(3)在“*3* *found*”的下方,语句的功能是使变量 v3 获得新值,它等于向量 v1 与向量 v2 之和。注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“*found*”。proj 3cpp#includeiostreamusing std:ostream;using std:cout;using std:endl;class MyVector
11、 f 表示二维向量的类 double x;x 坐标值double y; Y 坐标值 public: MyVector(double i=00,double j=00); 构造函数 MyVector operator+(MyVector j); 重载运算符+ friend MyVector operator 一(MyVec。tor i,MyVector j); 重载运算符一 friend ostream& operator (ostream&OS,MyVector v); 重载运算符;*1* *found*(double i,double j):X(i),y(j)MyVector MyVecto
12、r:operator+(MyVector j)return MyVector(x+jx,y+jy);MyVector operator 一(MyVector i,Myvector j)*2* *found*return MyVector(_);ostream&operator(ostream&os,MyVector V)OS (vX,vY);输出向量 v 的坐标 return os;int main() MyVector vl(2,3),v2(4,5),v3; *3* * found*v3=_;coutv3endl;return 0;(分数:2.00)_正确答案:(正确答案:(1)MyVector:MyVector (2)ixjx,iyjy (3)v1+v2)解析:解析:本题考查二维向量类 MyVector,其中涉及的知识点有构造函数,重载运算符+、一、