全国计算机二级C++考试试题及答案

来源:文书网 2.26W

  一、改错题

全国计算机二级C++考试试题及答案

使用VC6打开考生文件夹下的工程kt8_1,此工程包含一个源程序文件kt8_,但该程序运行有问题,请改正程序中的错误,使程序的输出结果如下:

f1functionofderive

f2functionofbase

f4functionofbase

源程序文件kt8_清单如下:

#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_中。

请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入所编写的若干语句。

文件kt8_的内容如下:

#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;

//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

using namespace std;

#define N 10

typedef struct ss

{

char num[10];

int s;

}STU;

void fun(STU a[],STU *s)

{

int i,min;

min=a[0].s;

for(i=0;i

{

if(min>a[i].s)

{

min=a[i].s;

*s=a[i];

}

}

}

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<<"*****The original date*****"<

cout<<"The lowest:"<

}

  三、综合应用题

使用VC6打开考生文件夹下的工程kt8_3,此工程包含一个源程序文件kt8_,该文件设计了用于输出乘法九九表的类。请认真阅读已有的代码,按要求完成下列操作,将程序补充完整

(1)定义类Table的私有数据成员x和y,分别用于表示九九表中的两个乘数(x*y),它们都是int型的数据。请在注释“//**1**”之后添加适当的语句。

(2)完成类Table的成员函数print()的定义,该函数以"x*y=z"的格式打印出九九表中的一个乘法算式,请使用格式化输出函数printf实现,在注释“//**2**”之后添加适当的语句。

(3)完成类Table9的成员函数print()的定义,该函数调用基类Table的print()函数,将九九表输出到屏幕,请在注释“//**3**”之后添加适当的语句。

(4)补充主函数,在屏幕上输出九九表,以便测试所定义的类的正确性。请在注释“//**4**”之后添加适当的语句。

注意:除在指定位置添加语句之外,请不要改动程序中的其他内容。

源程序文件kt8_清单如下:

#include

using namespace std;

class Table

{

private:

//**1**

int z;

public:

void print(int x,int y,int z);

};

void Table::print(int x,int y,int z)

{

//**2**

}

class Table9:public Table

{

public:

void print();

};

void Table9::print()

{

//**3**

int x,y,z;

for(i=1;i<10;i++)

{

for(j=1;j

{

x=i;

y=j;

z=i*j;

Table::print(y,x,z);

}

printf("n");

}

}

int main()

{

//**4**

return 0;

}

【参考答案】

(1)int x;

int y;

(2)printf( "%d*%d=%d ",x,y,z);

if(z<10) printf(" ");

(3)int i,j;

(4)Table9 t_9;

t_t();

【试题解析】主要考查将具体问题抽象为类,将类的定义补充完整,并进行类定义测试的能力。

#include

using namespace std;

class Table

{

private:

//**1**

int x;

int y;

int z;

public:

void print(int x,int y,int z);

};

void Table::print(int x,int y,int z)

{

//**2**

cout<

printf("t");

// printf( "%d*%d=%d ",x,y,z);

// if(z<10) printf(" ");

}

class Table9:public Table

{

public:

void print();

};

void Table9::print()

{

//**3**

int i,j;

int x,y,z;

for(i=1;i<10;i++)

{

for(j=1;j

{

x=i;

y=j;

z=i*j;

Table::print(y,x,z);

}

printf("n");

}

}

int main()

{

//**4**

Table9 a;

t();

return 0;

}

热门标签