《C++期末考試題及答案(共8頁(yè))》由會(huì)員分享,可在線閱讀,更多相關(guān)《C++期末考試題及答案(共8頁(yè))(8頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。
1、精選優(yōu)質(zhì)文檔-----傾情為你奉上
一、 選擇填空題(共20小題,每小題2分,共40分)。
1. 關(guān)于C++與C語(yǔ)言關(guān)系的描述中,(D )是錯(cuò)誤的。
a.C語(yǔ)言是C++語(yǔ)言的一個(gè)子集
b.C語(yǔ)言與C++語(yǔ)言是兼容的
c.C++語(yǔ)言對(duì)C語(yǔ)言進(jìn)行了一些改進(jìn)
d.C++語(yǔ)言和C語(yǔ)言都是面向?qū)ο蟮?
2.按照標(biāo)識(shí)符的要求,(A )符號(hào)不能組成標(biāo)識(shí)符。
a.連接符
b.下劃線
c.大小寫(xiě)字母
d.數(shù)字字符
3. 為了避免嵌套的if-else語(yǔ)句的二義性,C語(yǔ)言規(guī)定else總是與(C )組成配對(duì)關(guān)系。
a.縮排位置相同的if
b.在其之前未配對(duì)的if
2、c.在其之前未配對(duì)的最近的if
d.同一行上的if
4. 在"int a[ ][3]={{1},{3,2},{4,5,6},{0}};"中,a[2][2]的值是(C )。
a.1
b.0
c.6
d.2
5. 設(shè)"char **s;",以下正確的表達(dá)式是( B)。
a.s="computer";
b.*s="computer";
c.**s="computer";
d.*s=c;
6. 對(duì)于"int *pa[5];"的描述中,(D )是正確的。
a.pa是一個(gè)指向數(shù)組的指針,所指向的數(shù)組是5個(gè)int型元素
b.pa是一個(gè)指向某數(shù)組中第5個(gè)元素的
3、指針,該元素是int型變量
c.pa [5]表示某個(gè)元素的第5個(gè)元素的值
d.pa是一個(gè)具有5個(gè)元素的指針數(shù)組,每個(gè)元素是一個(gè)int型指針
7. 在下列表示引用的方法中,(A )是正確的。
已知:int m=10;
a.int &x=m;
b.int &y=10;
c.int &z;
d.float &t=&m;
8. 下列for循環(huán)的次數(shù)為(B)。
for(i=0, x=0; !x&&i<=5; i++)
a.5
b.6
c.1
d.無(wú)限
9. 對(duì)于C/C++語(yǔ)言的函數(shù),下列敘述中正確的是( A)。
a.函數(shù)的定義不能嵌套,但函數(shù)
4、調(diào)用可以嵌套
b.函數(shù)的定義可以嵌套,但函數(shù)調(diào)用不能嵌套
c.函數(shù)的定義和調(diào)用都不能嵌套
d.函數(shù)的定義和調(diào)用都可以嵌套
10. 在一個(gè)被調(diào)用函數(shù)中,關(guān)于return語(yǔ)句使用的描述,(D )是錯(cuò)誤的。
a.被調(diào)用函數(shù)中可以不用return語(yǔ)句
b.被調(diào)用函數(shù)中可以使用多個(gè)return語(yǔ)句
c.被調(diào)用函數(shù)中,如果有返回值,就一定要有return語(yǔ)句
d.被調(diào)用函數(shù)中,一個(gè)return語(yǔ)句可以返回多個(gè)值給調(diào)用函數(shù)
11. 在一個(gè)函數(shù)中,要求通過(guò)函數(shù)來(lái)實(shí)現(xiàn)一種不太復(fù)雜的功能,并且要求加快執(zhí)行速度,選用(A )。
a.內(nèi)聯(lián)函數(shù)
b.重載函數(shù)
c.遞歸調(diào)用
5、 d.嵌套調(diào)用
12. 使用fseek函數(shù)可以實(shí)現(xiàn)的操作是( A)。
a.改變文件指針的當(dāng)前位置
b.文件的順序讀寫(xiě)
c.文件的隨機(jī)讀寫(xiě)
d.以上都不對(duì)
13. 下列存儲(chǔ)標(biāo)識(shí)符中,(C )的可見(jiàn)性與存在性不一致。
a.外部類(lèi)
b.自動(dòng)類(lèi)
c.內(nèi)部靜態(tài)類(lèi)
d.寄存器類(lèi)
14. 在如下結(jié)構(gòu)定義中,不正確的是(B )。
a.struct student
{int no;
char name[10];
float score;
};
b.struct stud[20]
{
int no;
6、char name[10];
float score;
};
c.struct student
{
int no;
char name[10];
float score;
} stud[20];
d.struct
{
int no;
char name[10];
float score;
}stud[100] ;
15. 將兩個(gè)字符串連接起來(lái)組成一個(gè)字符串時(shí),選用(C )函數(shù)。
a.strlen( )
b.strcpy( )
c.strcat( )
d.s
7、trcmp( )
16. (D )不是構(gòu)造函數(shù)的特征
a.構(gòu)造函數(shù)的函數(shù)名與類(lèi)名相同
b.構(gòu)造函數(shù)可以重載
c.構(gòu)造函數(shù)可以設(shè)置缺省參數(shù)
d.構(gòu)造函數(shù)必須指定類(lèi)型說(shuō)明
17. 已知:類(lèi)A中一個(gè)成員函數(shù)說(shuō)明如下:
void Set(A&a);
其中,A&的含義是( C)。
a.指向類(lèi)A的指針為a
b.將a的地址值賦給變量Set
c.a是類(lèi)A對(duì)象的引用,用來(lái)作函數(shù)Set()的參數(shù)
d.變量A與a按位與作為函數(shù)Set( )的參數(shù)
18. 已知:print( )函數(shù)是一個(gè)類(lèi)的常成員函數(shù),它無(wú)返回值,下列表示中,(A )是正確的。
a.void pr
8、int( ) const;
b.const void print( );
c.void const print( );
d.void print(const);
19. 關(guān)于虛函數(shù)的描述中,(C )是正確的。
a.虛函數(shù)是一個(gè)static類(lèi)型的成員函數(shù)
b.虛函數(shù)是一個(gè)非成員函數(shù)
c.基類(lèi)中說(shuō)明了虛函數(shù)后,派生類(lèi)中將其對(duì)應(yīng)的函數(shù)可不必說(shuō)明為虛函數(shù)
d.派生類(lèi)的虛函數(shù)與基類(lèi)的虛函數(shù)具有不同的參數(shù)個(gè)數(shù)和類(lèi)型
20. 關(guān)于new運(yùn)算符的下列描述中,(D )是錯(cuò)的。
a.它可以用來(lái)動(dòng)態(tài)創(chuàng)建對(duì)象和對(duì)象數(shù)組
b.使用它創(chuàng)建的對(duì)象和對(duì)象數(shù)組可以使用運(yùn)算符delete刪
9、除
c.使用它創(chuàng)建對(duì)象時(shí)要調(diào)用構(gòu)造函數(shù)
d.使用它創(chuàng)建對(duì)象數(shù)組時(shí)必須指定初始值
二、問(wèn)答題(15分)
1、 (3分)虛析構(gòu)函數(shù)有什么作用?對(duì)象銷(xiāo)毀時(shí)要調(diào)用析構(gòu)函數(shù),如果不是定義的虛析構(gòu)函數(shù),基類(lèi)指針只能訪問(wèn)基類(lèi)析構(gòu),不能訪問(wèn)派生類(lèi)析構(gòu),若定義的虛析構(gòu)則可以解決這問(wèn)題
2、 (3分)拷貝構(gòu)造函數(shù)在哪幾種情況下調(diào)用?用一個(gè)對(duì)象初始化另一個(gè)對(duì)象;當(dāng)函數(shù)返回對(duì)象;當(dāng)對(duì)象作為函數(shù)參數(shù)傳遞。
3、 (4分)函數(shù)重載與函數(shù)覆蓋有什么不同,它們與多態(tài)有什么關(guān)系?函數(shù)重載函數(shù)名相同,而函數(shù)參數(shù)個(gè)數(shù),函數(shù)類(lèi)型不同;覆蓋是指函數(shù)名,函數(shù)個(gè)數(shù),函數(shù)類(lèi)型都相同。C++是通過(guò)虛函數(shù)的覆蓋,實(shí)現(xiàn)多態(tài)的功
10、能。
4、 (3分)C++繼承是如何工作的?
5、 (2分)類(lèi)與對(duì)象有什么區(qū)別?
三、(6分)分析下面程序的運(yùn)行結(jié)果
#include
class B
{
public:
B(){}
B(int i){b=i;}
virtual void virfun()
{
cout<<"B::virfun() called.\n";
}
private:
int b;
};
class D:public B
{
public:
D(){}
D(int i,int j):B(i){d=
11、j;}
private:
int d;
void virfun()
{
cout<<"D::virfun() called.\n";
}
};
void fun(B *obj)
{
obj->virfun();
}
void main()
{
D *pd=new D;
fun(pd);
}
四、(9分)下面的程序可以統(tǒng)計(jì)命令行第一個(gè)參數(shù)中出現(xiàn)的字母?jìng)€(gè)數(shù),請(qǐng)?zhí)畛湎旅婵瞻?,完成程序?
#include
#include
void main(int argc, a
12、rgv[];)
{
char *str;
int count=0;
if(argc<2)exit(1);
str= argv[1] ;
while(*str)
if(isalpha(*str++ )) count++;
printf("\n字母?jìng)€(gè)數(shù):%d\n",count);
}
提示:int isalpha(int ch)函數(shù)功能是檢查ch是否是字母
五、(8分) 定義一個(gè)字符棧類(lèi)Stack(包括類(lèi)的實(shí)現(xiàn))。數(shù)據(jù)成員包括一個(gè)存放字符的數(shù)組stck[ ]和一個(gè)棧指針tos。棧數(shù)組的尺寸由常量SIZE確定。棧的基本操作為Push()
13、和Pop()。
六、(10分)完成下面的函數(shù),對(duì)有n個(gè)元素的數(shù)組a,使數(shù)組元素按逆序排列。
void inverse(int *a, int n)
{
}
七、(12分)下面的函數(shù)統(tǒng)計(jì)子字符串substr在字符串str中出現(xiàn)的次數(shù),如果substr在str中不出現(xiàn),則返回值0。請(qǐng)完成該函數(shù)。
int str_count(char *substr, char *str)
{
}
一、 選擇填空題
1、D 2、A 3、C 4、C 5、B 6、D 7、A 8、B 9、A 10、D
11、A 12、A 13、C 14、B 15、C 16、D 17、C
14、18、A 19、C 20、D
二、問(wèn)答題
1、 虛析構(gòu)函數(shù)有什么作用?
解答要點(diǎn):
對(duì)象銷(xiāo)毀時(shí),需要調(diào)用析構(gòu)函數(shù)。在多態(tài)調(diào)用時(shí),是用基類(lèi)的指針訪問(wèn)派生類(lèi)的對(duì)象。如果析構(gòu)函數(shù)是非虛函數(shù),則基類(lèi)指針只能訪問(wèn)基類(lèi)的析構(gòu)函數(shù),而不能訪問(wèn)派生類(lèi)的析構(gòu)函數(shù),導(dǎo)致派生類(lèi)對(duì)象銷(xiāo)毀時(shí),沒(méi)有調(diào)用派生類(lèi)的析構(gòu)函數(shù),只是調(diào)用了基類(lèi)的析構(gòu)函數(shù)。如果把析構(gòu)函數(shù)定義成虛函數(shù),則可克服這個(gè)問(wèn)題。
2、 拷貝構(gòu)造函數(shù)在哪幾種情況下調(diào)用?
解答要點(diǎn):
用一個(gè)對(duì)象初始化另一個(gè)對(duì)象時(shí)
當(dāng)用對(duì)象作為函數(shù)參數(shù)傳遞時(shí)
當(dāng)函數(shù)返回對(duì)象時(shí)
3、 函數(shù)重載與函數(shù)覆蓋有什么不同,它們與多態(tài)有什么關(guān)系?
解答要點(diǎn):
函數(shù)重載是指
15、函數(shù)名相同,而函數(shù)的參數(shù)個(gè)數(shù)或類(lèi)型不同;覆蓋是指在派生類(lèi)中成員函數(shù)與基類(lèi)成員函數(shù)的函數(shù)名、參數(shù)個(gè)數(shù)、類(lèi)型與返回值均相同;C++中正是通過(guò)虛函數(shù)的覆蓋,實(shí)現(xiàn)多態(tài)的功能。
4、 C++繼承是如何工作的?
解答要點(diǎn):
繼承使得派生類(lèi)能夠使用基類(lèi)的公有和保護(hù)成員,從而實(shí)現(xiàn)代碼的復(fù)用,派生類(lèi)可以增加成員,也可以隱藏和覆蓋基類(lèi)的成員。對(duì)于公有繼承,基類(lèi)成員的訪問(wèn)權(quán)限在派生類(lèi)保持不變。
5、 類(lèi)與對(duì)象有什么區(qū)別?
解答要點(diǎn):
類(lèi)是類(lèi)型,是對(duì)象的抽象,對(duì)象是類(lèi)的具體實(shí)例。一個(gè)類(lèi)可以有多個(gè)對(duì)象,每個(gè)對(duì)象都有自己的存儲(chǔ)單元,而類(lèi)不占存儲(chǔ)單元。
三、運(yùn)行結(jié)果為: D::virfun() ca
16、lled.
四、填空
① char * ② argv[1] ③ *str++
五、(8分) 定義一個(gè)字符棧類(lèi)Stack(包括類(lèi)的實(shí)現(xiàn))。數(shù)據(jù)成員包括一個(gè)存放字符的數(shù)組stck[ ]和一個(gè)棧指針tos。棧數(shù)組的尺寸由常量SIZE確定。棧的基本操作為Push()和Pop()。
const int SIZE=27;
class Stack
{
public:
Stack():tos(0){};
void Push(char ch);
char Pop();
private:
char stck[SIZE];
int tos;
};
void S
17、tack::Push(char ch)
{
if(tos==SIZE)
cout<<"\nStack is full\n";
else{
stck[tos]=ch;tos++;
}
}
char Stack::Pop()
{
if(tos==0){
cout<<"\nStack is empty\n";
return 0;
}
tos--;
return stck[tos];
}
六、(10分)完成下面的函數(shù),對(duì)有n個(gè)元素的數(shù)組a,使數(shù)組元素按逆序排列。
void inverse(int *a, int n)
{
}
18、 int i,*p;
p=new int[n];
for(i=0;i<=n-1;i++)
p[i]=a[i];
for(i=0;i<=n-1;i++)
a[i]=p[n-i-1];
delete []p;
七、(12分)下面的函數(shù)統(tǒng)計(jì)子字符串substr在字符串str中出現(xiàn)的次數(shù),如果substr在str中不出現(xiàn),則返回值0。請(qǐng)完成該函數(shù)。
int str_count(char *substr, char *str)
{
}
int count=0;
char *pChar;
if(substr==NULL||str==NULL) return count;
while(*str!=\0){
pChar=substr;
while(*pChar==*str){
pChar++;
if(*pChar==\0){
count++;break;
}
else str++;
}//Match while(*pCh...) statement
str++;
}//Match while(*str...) statement
return count;
專(zhuān)心---專(zhuān)注---專(zhuān)業(yè)