1、国家二级 C+机试(操作题)模拟试卷 211及答案与解析 一、基本操作题 1 请使用 VC6或使用【答题】菜单打开考生文件夹 proj1下的工程 proj1。其中有线段类 Line的定义。程序中位于每个 “ ERROR*found*”之后的一行语句有错误,请加以改正。改正后程序的输出结果应该是: End point 1=(1, 8), End point 2=(5, 2), length=7 211 1。 注意:只修改每个 “ ERROR*found*”下的那一行,不要改动程序中 的其他内容。 1 #include 2 #include 3 using namespace std; 4 cla
2、ss Line; 5 double length(Line); 6 class Line 线段类 7 double x1 , y,1;线段端点 1 8 double x2, y2;线段端点 2 9 public: 10 ERROR *found* 11 Line(double x1, double y1, doublex2, double y2)const 12 this-x1: x1; 13 this-y1=y1; 14 this-x2=x2; 15 this-y2=y2; 16 17 double getXl()constreturn x1l; 18 double getYl()const
3、return y1; 19 double getX2()const return x2 20 double getY2()const return y2; 21 void show()const 22 cout “End point 1=(“ 2 include 3 using namespace std; 4 class Graphics 图形类 5 6 public: 7 Graphics(int e): edges(e)( 8 *found* 9 _; 10 protected: 11 int edges; 12 ; 13 class Squares: public Graphics正方
4、形类 14 15 public: 16 Squares(int x): Graphics(x) 17 void Draw(); 18 ; 19 void Squares: Draw() 20 21 int i, j; 22 if(edges0) 25 26 for(i=0; i0) 47 48 for(i=0; ie; 66 Graphics*objs2; 67 objs0=new Diamonds(e); 68 objs1=new Squares(e); 69 for(int i=0; iDraw(); 71 delete objs0; 72 delete objs1; 73 return
5、0; 74 三、综合应用题 3 请使用【答题】菜单命令或直接用 VC6打开考生文件夹下的工程 prog3,其中声明了 ValArray类,该类在内部维护一个动态分配的整型数组。 ValArray类的复制构造函数应实现对象的深层复制。请编写 ValArray类的复制构造函数。在 main函数中给出了一组测试数据,此种隋况下程序的输出应该是: ValArray vl=1, 2, 3, 4, 5 ValArray v2: 1, 2, 3, 4, 5 要求: 补充编制的内容写在 “ *333*”与 “ *666*”之间,不得修改程序的其他部分。 注意:程序最后将结果输出到文件 out dat中。输出函
6、数 writeToFile已经编译为 boj文件,并且在本程序中调用。 1 ValArray h 2 #include 3 using namespace std; 4 5 class ValArray 6 int*v; 7 int size; 8 public: 9 ValArray(const int*p, int n): size(n) 10 11 v=new intsize; 12 for(int i: 0; i0; i-) 【试题解析】 (1)由于 Graphic的子类都使用了 Draw()成员函数,并且都有自己各自不同的实现,很容易发现类中成员多态的特性,类的多态是使用虚函数来实现
7、的。 (2)Diamonds的成员函数 Draw()中使用了 edges。但是类 Diamonds中没有该成员,而 Graphic中有此成员,可知该类公有继承了 Graphic。 (3)根据图形的变化可知第一行 1个 *,第二行 3个 *,第三行 5个 *,增长的规律是 2*i+l,因而可以很容易得出结果。 (4)菱形的下半部分是由 5个 *开始递减的,即从最大边递减,直到为 0,可 以得出答案。 三、综合应用题 3 【正确答案】 1 size=other size; 2 v=new intsize; 3 for(int i =0; i size; i+) 4 setArray(i, other vi); 【试题解析】 主要考查考生对复制构造函数的掌握, ValArray类的复制构造函数应实现对象的深层复制。由 ValArray类的构造函数: 1 ValArray(const int* p, int n) : size(n) 2 3 v=new intsize;给 v分配大小为 size的空间 4 for (int i =0; i size; i+)遍历 p 5 vi=pi;把 pi赋值给 vi 6 可知类中 v是动态数组, size表示数组长度,因此要先给 v分配空间为 size,再逐个元素复制以达到对象的深层复制。