糯米文學吧

位置:首頁 > IT認證 > 計算機等級

全國計算機二級C++考試試題及答案

  一、改錯題

全國計算機二級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;

}