国家二级C++机试(操作题)模拟试卷281
基本操作题
1.请使用VC6或使用【答题】菜单打开考生文件夹proj1下的工程proj1,此工程中含有一个源程序文件proj1.cpp。其中位于每个注释“//ERROR*********found*********”之后的一行语句存在错误。请改正这些错误,使程序的输出结果为:
NUM=0
Value=1
注意:只修改注释“//ERROR ****found****”的下一行语句,不要改动程序中的其他内容。
//proj1.cpp
#include<iostream>
using namespace std;
class MyClasS{
int_i;
friend void Increment
(MyClass&f);
public:
const int NUN;
//ERROR *******found*******
MyClass(int i=0){NUN=0;
_i=i;
}
int GetValue()const { return_i;}
};
//ERROR*******found*******
void Increment(){f._i++;}
int main()
{
NyClass obj;
//ERROR *******found*******
NyClass∷Increment(obj);
cout <<\\
(1)MyClass(int i=0):NUM(0){
(2)void Increment(MyClass& f){f._i++;}
(3)Increment(obj);
解析:(1)主要考查考生对常量数据成员初始化方法的掌握,常量数据成员的初始化只能通过构造函数的成员初始化列表进行,并且要使用关键字const修饰。该题的前一条语句const int NUM;,说明NUM是常量数据成员。
(2)主要考查考生对友元函数的掌握,友元函数的定义与声明要一致,先看该友元函数的声明部分:friend void Increment(MyClass& f);,返回类型为void,函数参数为MyClass& f;再比较出错的语句:void Increment(){f._i++;},错误在于该函数没有参数,应把MyClass& f填在括号内。
(3)主要考查友元函数的调用,友元函数并不属于类,因此调用友元函数时不需要添加类名及作用域,只需要像调用普通函数一样即可。
简单应用题
2.请使用VC6或使用【答题】菜单打开考生文件夹proj2下的工程proj2,此工程包含一个源程序文件proj2.cpp。其中定义了Score类。
Score是一个用于管理考试成绩的类。其中,数据成员_s指向存储成绩的数组,_n表示成绩的个数;成员函数Sort使用冒泡排序法将全部成绩按升序进行排列。
请在程序中的横线处填写适当的代码,然后删除横线,以实现Score类的成员函数sort。
注意:只在指定位置编写适当代码,不要改动程序中的其他内容,也不要删除或移动“//****found****”。
//proj2.cpp
#include<iostream>
#include<cstdlib>
#include<ctime>
using namespace std;
class Score{
public:
Score(double*s,int n):_s(s),_(n){)
double GetScore(int i)const
{return _s[i];}
void Sort();
private:
double *_s;
int n;
};
void Score∷Sort()
{
//********found********
for(int i=0;i<_n-1;_______)
//********found********
for(int j=_______;j>i;j–)
if(_s[j]<_s[j-1])
( //交换_s[j]和_s[j-1]
double t=_s[j];
//********found********
________:
//********found********
________;
}
}
int main()
{
const int NUN =10;
double s[NUM];
stand(time(0));
for(int i=0;i<NUN i++)
s[i]=double(rand())/
RAND_MAX * 100;
Score ss(s,NUM);
ss.Sort();
for(int j=0;J<NUM;j++)
cout << ss.GetScore(J) <<end1;
return 0;
}
(1)i++
(2)_n-1
(3)_s[j]=_s[j-1]
(4)_s[j-1]=t
解析:(1)主要考查for循环语句,从题目要求可知循环变量i要从0到_n-2,因此i要递增操作,即i++。
(2)主要考查考生对冒泡排序的掌握,这里要求从后往前扫描,比较相邻两个元素,若后者小则交换,因此在这里下标j要从最后开始,即int j=_n_1。
(3)考查交换算法,在if语句中_s[j]<_s[j-1]满足条件,则实现交换。因为已经把_s[j]的值赋给了中间变量t,所以这里要把_s[j-1]的值赋给_s[j],即_s[j]=_s[j-1];。
(4)考查交换算法,这里只需把中间变量t中的值赋给_s[j-1]即可。
综合应用题
3.请使用VC6或使用【答题】菜单打开考生文件夹proj3下的工程prog3,其中声明了ValArray类,该类在内部维护一个动态分配的整型数组。ValArray类的复制构造函数应实现对象的深层复制。请编写ValArray类的复制构造函数。在main函数中给出了一组测试数据,此种情况下程序的输出应该是:
ValArray v1={1,2,3,4,5}
ValArray v2={2,2,2,2,2}
要求:
补充编制的内容写在“//*******333*******”与“//********666********”之间。不要修改程序的其他部分。
注意:
相关文件包括:main.cpp、ValArray.h。
程序最后调用writeTo
本文档预览:3600字符,共4673字符,源文件无水印,下载后包含无答案版和有答案版,查看完整word版点下载