1、国家二级 C+机试(操作题)模拟试卷 125及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 projl下的工程 projl,此工程中含有 个源程序文件 projl cpp。其中位于每个注释 “ERROR*found*”之后的 行语句存在错误。请改正这些错误,使程序的输出结果为: NUM=0 Value=1 注意:只修改注释 “ ERROR *found*”的下一行语句,不要改动程序中的其他内容。 projl cpp #include using namespace std; class MyClass int i; friend void Increment(
2、MyClass f); public: const int NUM; ERROR* found* MyClass(int i=0)NUM=0; _i=i; int GetValue()constreturn i; ) ; ERROR*found* void Increment()f i+; ) int main() MyClass obj; ERROR*found* MyClass: Increment(obj); cout #include #include using namespace std; class Score public: Score(double*S, int n): s(
3、S), n (n) double GetScore(int i)constreturn Si; ) void Sort(); private: double* S; int n; ; void Score: Sort() * found* for(int i=0; ii; J一一 ) _。 if(一 SJ using namespace std; clas s ValArray int*v; int Size; public: ValArray(const int*P, int n): Size(n) V=new int Size; for(int i=0; iSize; i+) vi=Pi;
4、 ValArray(const ValArray void writeToFile(const char*); main cpp #include“ValArray h” ValArray: ValArray(const ValArray& other) *333* *666* int main() const int a=l, 2, 3, 4, 5 J; ValArray v1(a, 5); ValArray V2(V1); for(int i=0; i5; i+) v2 setElement(i, 2); cout“ValArray vl=”; v1 print(cout); couten
5、dl; cout“ValArray v2=”; v2 print(cout); coutendl; writeToFile(“”); return 0; 国家二级 C+机试(操作题)模拟试卷 125答案与解析 一、基本操作题 1 【正确答案】 (1)MyClass(int i O): NUM(0) (2)void Increment(MyClass&f)f j+; (3)Increment(0bj); 【试题解析】 本题考查的是 MyClass类,其中涉及友元函数、构造函数、常量数据成员、成员函数和友元函数的调用。友元函数的定义要与函数声明相呼应,即返回值、参数类型、参数个数要一致。友元函数的
6、调用不需要使用类名和作用域。 【解题思路】 (1)主要考查考生对常量数据成员初始化方法的掌握,常量数据成员的初始化只能通过构造函数的成员初始化列表进行, 并且要使用关键字 const修饰。该题的前一条语句 const int NUM;,说明 NUM是常量数据成员。 (2)主要考查考生对友元函数的掌握,友元函数的定义与声明要一致,先看该友元函数的声明部分: friend void In crement(MyClass&f);,返回类型为 void,函数参数为 MyClass&f;再比较出错的语句: void Increment()f i+; ,错误在于该函数没有参数,应把 MyClass&f填在
7、括号内。 (3)主要考查友元函数的调用,友元函数并不属于类,因此调用友元函数 时不需要添加类名及作用域,只需要像调用普通函数一样即可。 【解题宝典】类的常量数据成员初始化必须使用成员初始化列表进行,否则必然出错。友元函数与普通函数的区别在于,友元函数可以通过对象名调用类的全部成员,包括私有成员。所有函数的声明和定义必须一致,包括函数返回值、参数类型、参数个数及有无 const关键字。 二、简单应用题 2 【正确答案】 (1)i+ (2)一 n1 (3)一 sj=一 sj1 (4)一 sj一 1 =t 【试题解析】 本题考查 Score类,其中涉及构造函数、成员函数和 排序算法。 【解题思路】
8、(1)主要考查 for循环语句,从题目要求可知循环变量 i要从 0到一 n一 2,因此 i要递增操作,即 i+。 (2)主要考查考生对冒泡排序的掌握,这里要求从后往前扫描,比较相邻两个元素,若后者小则交换,因此在这里下标 j要从最后开始,即 int j=一 n 1。 (3)考查交换算法,在 if语句中一 sj一 sj 1满足条件,则实现交换。因为已经把一 sj的值赋给了中间变量 t,所以这里要把一 sj一 1的值赋给一 sj,即一sj=一 sj一 1;。 (4)考查交换算法,这里只需把中间 变量 t中的值赋给 _sj 1即可。 【解题宝典】 本题考查的是考生对冒泡排序算法的掌握,要记住冒泡排序
9、的思想是两两比较待排序序列中的元素,并交换不满足顺序要求的各对元素,直到全部满足顺序要求为止。 三、综合应用题 3 【正确答案】 S1ze=other s1 ze; 把对象数组的大小赋值给 sizev=DeW int other size ; 根据对象数组的大小动态分配数组 vfor(int i=0; isize; +i) vi=other vi; 遍历整个对象的数组把 值 other vi放到数组 v中 【试题解析】 本题主要考查的是 ValArray类,其中涉及构造函数、成员函数和析构函数。题目要求编写 ValArray类的复制构造函数,以实现对象的深层复制。即填写 ValArray: ValArray(const ValArray&other)函数的函数体。 【解题思路】 主要考查考生对复制构造函数的掌握。由函数名: Val-Array: ValArray(const ValArray&other),知道要复制的对象是 other,对由 Val Array类的成员: int木 v; int size;知道要复制的内容是动态数组 v及整型变量 size。动态数组要使用new语句分配内存,最后利用 for循环语句来完成复制过程。
copyright@ 2008-2019 麦多课文库(www.mydoc123.com)网站版权所有
备案/许可证编号:苏ICP备17064731号-1