1、国家二级 C+机试(操作题)-试卷 8 及答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6 打开考生文件夹下的源程序文件 modi1cpp,该程序运行时有错,请改正其中的错误,使得程序正常运行,并使程序输出的结果为:init TestClassdel TestClass 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在*error*的下面。#includeiostreamhclass TeStClass*error*error*int TestClass()cout“init TestClass“en
2、dl;*error*voidTestClass()cout“del TestClass“endl;void main()TestClass obj;return;(分数:2.00)_二、简单应用题(总题数:1,分数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。阅读下列函数说明和代码,完成空出部分程序。该程序从键盘读入整数,并按从大到小的顺序输出输入整数中互不相等的那些整数。程序一边读入整数,一边构造一个以大到小顺序链接的链表,直至输入 0 时结束。然后顺序输出链表上各表元的整数值。主函数每读入一个整数,就调用函数 fun(),函数 fun()将还未出现在链表上的
3、整数按从大到小的顺序插入到链表中。为了插入方便,链表在表首有一个辅助表元。注意:不能修改程序的其他部分,只能修改 fun()函数。#includeiostreamclass NODEpublic:int data;NODE *next;void fun(NODE *list,int x)void main()intx;NODE *head,*p;*首先建立只有辅助袁元的空链表*head=new NODE;head-next=NULL;std:cout“Enter integers, end with0“std:endl;while(1)std:cinx;if(x=0)break;fun(hea
4、d,x),for(p=head-next;p!=NULL;p=p-next;std:coutp-data ;std:coutStd:endl;dop=head-next;delete head;head=p;)while(p);(分数:2.00)_三、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生文件夹下的源程序文件 modi3cpp。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。其中:定义了类 circle 和 column,column 类由 circle 类 protected 派生,但是两个类的定义并不完整,请按照以下的要求,将程序补充完整。(1)定
5、义类 circle 的保护数据成员函数 r和 area,它们都是 double 型的数据,请在注释*1*后完成。(2)添加类 circle 的无参数的构造函数,使得类 circle 对象的 r 默认值为 0,请在注释*2*后完成。(3)添加派生类 column 的构造函数的定义,使得参数为 double 型的 height 和 radius 并将其分别赋给数据成员h 和基类的 r 请在注释*3*之后完成。(4)完成派生类 column 的成员函数 print()的定义,请在注释*4*之后完成,使得输出为:radius=5 area=7854height=10 vol=7854 注意:增加代码,
6、或者修改代码的位置已经用符号表示出来。请不要修改其他的程序代码。#includeiostreamhconst double pi=31416;class circleprotected:*1*public:*2*r=00;Circle(double radius)r=radius;void print()area=r*r* pi;cout“radius=“r “area=“areaendl;class column:protected circleprotected:double h;public:*3*h=height;r=radius;void print()circle:print();
7、*4*;int main()column col(50,100)jcolprint();return0;(分数:2.00)_国家二级 C+机试(操作题)-试卷 8 答案解析(总分:6.00,做题时间:90 分钟)一、基本操作题(总题数:1,分数:2.00)1.使用 VC6 打开考生文件夹下的源程序文件 modi1cpp,该程序运行时有错,请改正其中的错误,使得程序正常运行,并使程序输出的结果为:init TestClassdel TestClass 注意:不要改动 main 函数,不能增行或删行,也不能更改程序的结构,错误的语句在*error*的下面。#includeiostreamhclas
8、s TeStClass*error*error*int TestClass()cout“init TestClass“endl;*error*voidTestClass()cout“del TestClass“endl;void main()TestClass obj;return;(分数:2.00)_正确答案:(正确答案:(1)添加语句:public: (2)TestClass()cout“init TestClass:endl;);(3)TestClass()(cout“del TestClass“endl;)解析:解析:(1)打开 modilcpp,调试程序,显示错误提示为第一标识下“m
9、odilcpp(13):error C2248:TestClass:TestClass;cannot access private member declared in classTestClass”,构造函数由于是私有的,无法获得,所以应该定义为 public 型,即第 1 个标识下添加“public:”。 (2)构造函数首部的一般形式为:构造函数名(形参列表),构造函数没有返回值,所以定义构造函数时不需要声明类型,所以“int TestClass()cout“init TestClass“endl;”语句修改为“TestClass()cout“iniit TestClass“endl;”。
10、 (3)析构函数的名字是类名的前面加一个“”符号,所以“voidTestClass()cout“del TestClass“endl;);”修改为“TestClass()cout“del TestClass“endl;”。二、简单应用题(总题数:1,分数:2.00)2.使用 VC6 打开考生文件夹下的源程序文件 modi2cpp。阅读下列函数说明和代码,完成空出部分程序。该程序从键盘读入整数,并按从大到小的顺序输出输入整数中互不相等的那些整数。程序一边读入整数,一边构造一个以大到小顺序链接的链表,直至输入 0 时结束。然后顺序输出链表上各表元的整数值。主函数每读入一个整数,就调用函数 fun(
11、),函数 fun()将还未出现在链表上的整数按从大到小的顺序插入到链表中。为了插入方便,链表在表首有一个辅助表元。注意:不能修改程序的其他部分,只能修改 fun()函数。#includeiostreamclass NODEpublic:int data;NODE *next;void fun(NODE *list,int x)void main()intx;NODE *head,*p;*首先建立只有辅助袁元的空链表*head=new NODE;head-next=NULL;std:cout“Enter integers, end with0“std:endl;while(1)std:cinx;
12、if(x=0)break;fun(head,x),for(p=head-next;p!=NULL;p=p-next;std:coutp-data ;std:coutStd:endl;dop=head-next;delete head;head=p;)while(p);(分数:2.00)_正确答案:(正确答案:NODE*u,*v,*p; u=list; v=u-next; while(v!=NULL&xv-data)寻找插入的位置 u=v; v=v-next; if(v=NULL|xv-data)判断是否为新的元素 p=new NODE; P-data=x;生成新的元素 p-next=v; u-
13、next=p;插入新的元素 )解析:解析:(1)首先利用 while 循环寻找插入元素的位置。 (2)然后判断要插入的元素是否为新元素。 (3)如果为新元素,那么执行单链表的操作,插入元素。三、综合应用题(总题数:1,分数:2.00)3.使用 VC6 打开考生文件夹下的源程序文件 modi3cpp。其中定义的类并不完整,按要求完成下列操作,将类的定义补充完整。其中:定义了类 circle 和 column,column 类由 circle 类 protected 派生,但是两个类的定义并不完整,请按照以下的要求,将程序补充完整。(1)定义类 circle 的保护数据成员函数 r和 area,它
14、们都是 double 型的数据,请在注释*1*后完成。(2)添加类 circle 的无参数的构造函数,使得类 circle 对象的 r 默认值为 0,请在注释*2*后完成。(3)添加派生类 column 的构造函数的定义,使得参数为 double 型的 height 和 radius 并将其分别赋给数据成员h 和基类的 r 请在注释*3*之后完成。(4)完成派生类 column 的成员函数 print()的定义,请在注释*4*之后完成,使得输出为:radius=5 area=7854height=10 vol=7854 注意:增加代码,或者修改代码的位置已经用符号表示出来。请不要修改其他的程序
15、代码。#includeiostreamhconst double pi=31416;class circleprotected:*1*public:*2*r=00;Circle(double radius)r=radius;void print()area=r*r* pi;cout“radius=“r “area=“areaendl;class column:protected circleprotected:double h;public:*3*h=height;r=radius;void print()circle:print();*4*;int main()column col(50,1
16、00)jcolprint();return0;(分数:2.00)_正确答案:(正确答案:(1)添加语句:double r,area; (2)添加语句:circle() (3)添加语句:column(double radius,double height) (4)添加语句:cout“height=“Ifh “vol=“area*hendl;)解析:解析:(1)题目 1 要求“定义类 circle 的保护数据成员函数 r 和 area,它们都是 double 型的数据”。保护成员与 private 和 public 一样是用来声明成员的访问权限的。在已有程序 circle 类中的protected
17、:区域,添加变量 r 和 area 的定义,即“double r,area;”。 (2)题目 2 要求“添加类circle 的无参数的构造函数,使得类 circle 对象的 r 默认值为 0”。在 C+中,构造函数是一种特殊的成员函数,它的名字与类同名,没有参数的构造函数一般形式为:构造函数名(),所以这里添加“circle()”。 (3)题目 3 要求“添加派生类 column 的构造函数的定义”。同(2),另外带参数的构造函数的一般格式为:构造函数名(类型 1 形参 1,类型 2 形参 2,),所以这里添加“column(doubleradius,doubleheight)”。 (4)题目 4 要求“完成派生类 column 的成员函数 print()的定义”。根据题干中输出结果,知道第一个输出值为 height,第二 4 个输出值为 vol,即 area*h,所以这里添加“cOut”height=“h “vol=“area*hendl;”。