全国计算机二级C++考试试题及答案
全国计算机二级C++考试试题及答案
一、改错题
使用VC6打开考生文件夹下的工程kt8_1,此工程包含一个源程序文件kt8_1.cpp,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:
f1functionofderive
f2functionofbase
f4functionofbase
源程序文件kt8_1.cpp清单如下:
#include
using namespace std;
class base
{
public:
/**********found**********/
void f1(){cout<<"f1 function of base"<
virtual void f2(){cout<<"f2 function of base"<
virtual void f3(){cout<<"f3 function of base"<
void f4(){cout<<"f4 function of base"<
};
/**********found**********/
class derive::public base
{
void f1(){cout<<"f1 function of derive"<
void f2(int x){cout<<"f2 function of derive"<
void f4(){cout<<"f4 function of derive"<
};
void main()
{
base *p;
derive obj2;
/**********found**********/
p=obj2;
p->f1();
p->f2();
p->f4();
}
【参考答案】
(1)将void f1(){cout<<"f1 function of base"<
改为:virtual void f1(){cout<<"f1 function of base"<
(2)将class derive::public base
改为:class derive:public base
(3)将p=obj2;
改为:p=&obj2;
【试题解析】
(1)主要考查对虚函数的深刻理解,虚函数是动态联编的基础,也是实现多态性的重要方法,它可以根据不同的情况动态的选择执行哪一个函数。在派生类中实现虚函数应该满足与基类的'同名函数完全相同,并且使用关键字virtual修饰,本题中由输出结果中的f1 function of derive可知,必须将基类base的成员函数f1()定义为虚函数;
(2)主要考查对派生类定义格式的掌握,应该使用“:”后面是继承列表,而“::”是作用域符;
(3)主要考查类对象的定义与使用,p是一个指针类型的变量,给它的赋值应该是一个地址,即使用取地址操作符&。
#include
using namespace std;
class base
{
public:
/**********found**********/
virtual void f1(){cout<<"f1 function of base"<
virtual void f2(){cout<<"f2 function of base"<
virtual void f3(){cout<<"f3 function of base"<
void f4(){cout<<"f4 function of base"<
};
/**********found**********/
class derive:public base //class derive::public base
{
void f1(){cout<<"f1 function of derive"<
void f2(int x){cout<<"f2 function of derive"<
void f4(){cout<<"f4 function of derive"<
};
void main()
{
base *p;
derive obj2;
/**********found**********/
p=&obj2;
p->f1();
p->f2();
p->f4();
}
二、简单应用题
已知考生的记录由学号和学习成绩构成,N名考生的数据已存入a结构体数组中。请编写函数fun,该函数的功能是:出成绩最低的考生记录,通过形参返回主函数(规定只有一个最低分)。已给予出函数的首部,请完成该函数
注意:部分源程序已存在文件kt8_2.cpp中。
请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。
文件kt8_2.cpp的内容如下:
#include
#include
#include
using namespace std;
#define N 10
typedef struct ss
{
char num[10];
int s;
}STU;
void fun(STU a[],STU *s)
{
}
void main()
{
STU a[N]={{"A01",81},{"A02",89},{"A03",66},{"A04",87},{"A05",77},{"A06",90},{"A07",79},{"A08",61},{"A09",80},{"A10",71}},m;
fun(a,&m);
cout<<"*****Theoriginaldate*****"<
cout<<"The lowest:"<
}
【参考答案】
void fun(STU a[],STU *s)
{
int i,min;
min=a[0].s;
输出函数printf使用方法//a[i].s中到最小的,并将a[i]赋值给*s
for(i=0;i
{
if(min>a[i].s)
{
min=a[i].s;
*s=a[i];
}
}
}
【试题解析】
解题思路为:先假设第一个考生的成绩最优,通过循环到最低成绩,并将最低成绩的考生记录传给指针s,带回主函数。
#include
#include
#include