1、二级 C+机试-28 及答案解析(总分:100.00,做题时间:90 分钟)一、1改错题(总题数:1,分数:30.00)1.使用 VC6 打开考生文件夹下的工程 test23_1,此工程包含一个源程序文件 test23_1.cpp,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:iizO1222源程序文件 test23_1.cpp 清单如下:#includeiostream.h#includestdio.hclass innerclassint x; public:/*found*/innerclass(int z) x=z; cout“iz“endl;/*found*/void
2、 write( ) print(“%d/n“,x);class outerclassint y;innerclass g;innerclass *h;public:outerclass(int a);void write( ) printf(“%d/n“,y); void write_inner_g() g.write(); void write_inner_h() h-write();outerclass:outerclass(int a) /*found*/h=new innerclass(12);cout“o“endl; int main ( ) outerclass ob(22);ob
3、.write_inner_h();ob.write();return 1; (分数:30.00)填空项 1:_二、2简单应用题(总题数:1,分数:40.00)2.请编写一个函数 void bubble(double data,int length),其中 data 是一维数组,存放比较的数据,length 是数组中存放元素的个数,用冒泡法将数据(个数可变)捧序后由小到大输出。冒泡法是常用的排序算法,这种算法执行效率不高,但比较简单,就是将相邻的两个数据作比较,把较小的数据交换到前面。纵向看来,交换过程中较小的数据就好像水中的气泡不断浮起。要求使用 for 循环实现算法。注意:部分源程序已存在文
4、件 test23_2.cpp 中。请勿修改主函数 main 和其他函数中的任何内容,仅在函数 bubble 的花括号中填写若干语句。文件 test23_.cpp 的内容如下:#includeiostream.hvoid bubble(double data,int length)void main ()int n;cout “请输入数据的个数“;cinn;double* ddata = new doublen;for(int i = 0; i n; i+)cout“No.“i+1“: “;cinddatai;bubble (ddata, n);cout“排序后输出数据:“endl;for(i
5、= O; in; i+)cout“No.“i+1“:“;coutddataiendl;(分数:40.00)_三、3综合应用题(总题数:1,分数:30.00)3.使用 VC6 打开考生文件夹下的工程 test23_3,此工程包含一个源程序文件 test23_3.cpp,其中定义了类X 和它的友元类 Y,但它们的定义并不完整。请按要求完成下列操作,将程序补充完整。(1)将类 X 的静态数据成员 y 初始化为 1。请在注释“/*1*”之后添加适当的语句。(2)完成类 Y 的构造函数 Y(int i,int j)的定义,将参数 i 赋值给类 Y 的数据成员,X 的对象 a 中的数据成员 x,并且把参数
6、 j 赋值给类 X 的数据成员 y,请在注释“/*2*”之后添加适当的语句。(3)完成类 Y 的成员函数 void Display()的定义,将 Y 的数据成员,X 的对象 a 中的数据成员 x 和类 X 的数据成员 y 按照“x=_,y=_”的形式显示出来(“_”代表一个数字),请在注释“/*3*”之后添加适当的语句。输出结果如下:x=5,y=lx=6,y=9x=5,y=9注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。源程序文件 test23_3.cpp 清单如下:includeiostream.hclass Xfriend class Y;public:void Set(in
7、t i) x=i;void Display()cout“x=“x“,“;cout“y=“yendl;private:int x;static int y;class Ypublic:Y(int i, int j)void Display(); private:X a;/*1* Y:Y(int i, int j) /*2* void Y:Display()/*3* void main ( ) X b;b.Set(5);b.Display();Y c(6,9);c.Display();b.Display(); (分数:30.00)_二级 C+机试-28 答案解析(总分:100.00,做题时间:90
8、 分钟)一、1改错题(总题数:1,分数:30.00)1.使用 VC6 打开考生文件夹下的工程 test23_1,此工程包含一个源程序文件 test23_1.cpp,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:iizO1222源程序文件 test23_1.cpp 清单如下:#includeiostream.h#includestdio.hclass innerclassint x; public:/*found*/innerclass(int z) x=z; cout“iz“endl;/*found*/void write( ) print(“%d/n“,x);class ou
9、terclassint y;innerclass g;innerclass *h;public:outerclass(int a);void write( ) printf(“%d/n“,y); void write_inner_g() g.write(); void write_inner_h() h-write();outerclass:outerclass(int a) /*found*/h=new innerclass(12);cout“o“endl; int main ( ) outerclass ob(22);ob.write_inner_h();ob.write();return
10、 1; (分数:30.00)填空项 1:_ (正确答案:(1)错误:缺少缺省的构造函数正确:innerclass()cout“i“endl;(2)错误:void write()print(“%d/n“,x);正确:void write()printf(“%d/n“,x);(3)错误:缺少赋值语句正确:y=a;)解析:解析(1)主要考查考生对于派生类调用基类构造函数的应用,此处必须定义缺省的构造函数(g 调用);(2)主要考查考生对于格式化输出的掌握,应该使用函数 printf,其中的%d 表示是输出整型: (3)主要考查考生对于构造函数作用的掌握,只有在此处赋值才能将 22 显示出来,因为构造
11、函数在声明对象的时候会被自动的调用。二、2简单应用题(总题数:1,分数:40.00)2.请编写一个函数 void bubble(double data,int length),其中 data 是一维数组,存放比较的数据,length 是数组中存放元素的个数,用冒泡法将数据(个数可变)捧序后由小到大输出。冒泡法是常用的排序算法,这种算法执行效率不高,但比较简单,就是将相邻的两个数据作比较,把较小的数据交换到前面。纵向看来,交换过程中较小的数据就好像水中的气泡不断浮起。要求使用 for 循环实现算法。注意:部分源程序已存在文件 test23_2.cpp 中。请勿修改主函数 main 和其他函数中的
12、任何内容,仅在函数 bubble 的花括号中填写若干语句。文件 test23_.cpp 的内容如下:#includeiostream.hvoid bubble(double data,int length)void main ()int n;cout “请输入数据的个数“;cinn;double* ddata = new doublen;for(int i = 0; i n; i+)cout“No.“i+1“: “;cinddatai;bubble (ddata, n);cout“排序后输出数据:“endl;for(i = O; in; i+)cout“No.“i+1“:“;coutddata
13、iendl;(分数:40.00)_正确答案:(void bubble(double data,int length)int segment;int loop;double temp;for(segment=0;segment=length-2;segment+)for(1oop=length-2;loop=segment;loop-)if(dataloop+1dataloop)temp=dataloop;dataloop =data loop+1;dataloop+1=temp;)解析:解析本题考查的是考生使用 for 循环和常用的冒泡排序法的综合水平。冒泡排序法就是将相邻的两个数据作比较,把
14、较小的数据交换到前面,以此类推。这是经典的算法应该掌握。三、3综合应用题(总题数:1,分数:30.00)3.使用 VC6 打开考生文件夹下的工程 test23_3,此工程包含一个源程序文件 test23_3.cpp,其中定义了类X 和它的友元类 Y,但它们的定义并不完整。请按要求完成下列操作,将程序补充完整。(1)将类 X 的静态数据成员 y 初始化为 1。请在注释“/*1*”之后添加适当的语句。(2)完成类 Y 的构造函数 Y(int i,int j)的定义,将参数 i 赋值给类 Y 的数据成员,X 的对象 a 中的数据成员 x,并且把参数 j 赋值给类 X 的数据成员 y,请在注释“/*2
15、*”之后添加适当的语句。(3)完成类 Y 的成员函数 void Display()的定义,将 Y 的数据成员,X 的对象 a 中的数据成员 x 和类 X 的数据成员 y 按照“x=_,y=_”的形式显示出来(“_”代表一个数字),请在注释“/*3*”之后添加适当的语句。输出结果如下:x=5,y=lx=6,y=9x=5,y=9注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。源程序文件 test23_3.cpp 清单如下:includeiostream.hclass Xfriend class Y;public:void Set(int i) x=i;void Display()cou
16、t“x=“x“,“;cout“y=“yendl;private:int x;static int y;class Ypublic:Y(int i, int j)void Display(); private:X a;/*1* Y:Y(int i, int j) /*2* void Y:Display()/*3* void main ( ) X b;b.Set(5);b.Display();Y c(6,9);c.Display();b.Display(); (分数:30.00)_正确答案:(1)int X:y=1;(2)a.x=i;X;y=j;(3)cout“X=“a.x“,“;cout“y=“X:yendl;)解析:解析本题主要考查考生对于友元类的定义和使用友元类访问的应用,注意(1)中类 X 的静态成员y 应该在类外初始化,而(2)和(3)中对于 x 和 y 不同的访问方式就是因为 y 是静态成员,是类 X 的所有对象公有的,必须使用作用域符“:”进行访问。