C++期末考試題及答案_第1頁
C++期末考試題及答案_第2頁
C++期末考試題及答案_第3頁
C++期末考試題及答案_第4頁
C++期末考試題及答案_第5頁
已閱讀5頁,還剩11頁未讀, 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡介

1、清華大學(xué)計(jì)算機(jī)系C+期末考試題及答案一、 填空題(25小題,共50分)(以下每小題1分,共10分)1 在C+中,函數(shù)的參數(shù)有兩種傳遞方式,它們是值傳遞和 地址或指針或引用傳遞。2 當(dāng)一個(gè)成員函數(shù)被調(diào)用時(shí),該成員函數(shù)的 this指針 指向調(diào)用它的對(duì)象。3在基類和派生類中,派生類可以定義其基類中不具備的數(shù)據(jù)和操作。對(duì)兩個(gè)有相同名字的數(shù)據(jù)成員進(jìn)行訪問時(shí),如果沒有 作用域分隔符限定時(shí) ,對(duì)此數(shù)據(jù)成員的訪問將出現(xiàn)歧義。4 拷貝構(gòu)造函數(shù)使用 引用 作為參數(shù)初始化創(chuàng)建中的對(duì)象。5 在公有繼承的情況下,基類數(shù)據(jù)成員在派生類中的訪問權(quán)限 保持不變 。6 描述命題A小于B或小于C的表達(dá)式為 AB|Ac&b=c的值

2、是 0 。(以下每小題2分,共20分)11 面向?qū)ο蟮某绦蛟O(shè)計(jì)有四大特征,它們是抽象、封裝、 繼承 、 多態(tài) 。12 在Visual C+中,定義重載函數(shù)時(shí),應(yīng)至少使重載函數(shù)的參數(shù)個(gè)數(shù)或參數(shù)類型 不同 ;在基類和派生類中,成員函數(shù)的覆蓋是指 派生類成員函數(shù)與在基類被覆蓋的成員函數(shù)名、參數(shù)個(gè)數(shù)、參數(shù)類型和返回值類型均相同 。13構(gòu)造函數(shù)與析構(gòu)函數(shù)除功能不同外,在定義形式上,它們的區(qū)別還包括構(gòu)造函數(shù)名與類名相同,而析構(gòu)函數(shù)名是在類名前加一個(gè)、 析構(gòu)函數(shù)沒有參數(shù) 、析構(gòu)函數(shù)可以定義為虛函數(shù) 。14 動(dòng)態(tài)聯(lián)編要滿足兩個(gè)條件,它們是 被調(diào)用的成員函數(shù)是虛函數(shù) 、用指針或引用調(diào)用虛函數(shù) 。15在C+類中,

3、有一種不能定義對(duì)象的類,這樣的類只能被繼承,稱之為 抽象類 ,定義該類至少具有一個(gè) 純虛函數(shù) 。16 在C+類中,const關(guān)鍵字可以修飾對(duì)象和成員函數(shù),const對(duì)象不能 被修改 ,const成員函數(shù)不能 修改類數(shù)據(jù)成員 。17 舉出C+中兩種用戶自定義的數(shù)據(jù)類型: 類 、 枚舉 。18 C+中沒有字符串類型,字符串是通過 字符數(shù)組 來表示的,每一個(gè)字符串都有一個(gè)結(jié)尾字符 0 。19 C+中沒有輸入輸出語句,輸入輸出是通過 輸入輸出庫 實(shí)現(xiàn)的,寫出一條打印整型變量n的輸出語句:coutn;20 舉出C+中兩種代碼復(fù)用的方式: 繼承 、復(fù)用 。1. 單選:10*22. 簡答:4*53. 程序分

4、析:5*84. 程序設(shè)計(jì):2*10考點(diǎn):(1) 運(yùn)算符重載(2) 文件IO流(3) 異常處理(以下每小題4分,共20分)21 下面程序的運(yùn)行結(jié)果是3。#include void main()char a=a,b=j;float x;x=(b-a)/(F-A);printf(%dn,(int)(3.14*x);22 下面程序的運(yùn)行結(jié)果是2 5 8 11 14。#include iostream.hvoid main( )int i=1;while (i=15)i+;if (i%3!=2) continue;else cout i=iendl;23 下面程序的運(yùn)行結(jié)果是_。#include ios

5、tream.hclass testprivate:int num;float fl;public:test( );int getint( )return num;float getfloat( )return fl;test( );test:test( )cout Initalizing default endl;num=0;fl=0.0;test:test( )cout Desdtructor is active endl;void main( )test array2;cout array1.getint( ) array1.getfloat( ) endl;Initalizing def

6、aultInitalizing default0 0Desdtructor is activeDesdtructor is active24 下面程序的運(yùn)行結(jié)果是_。#include class Apublic:A()coutA:A() called.n;virtual A()coutA:A() called.n;class B:public Apublic:B(int i)coutB:B() called.n;buf=new chari;virtual B()delete buf;coutB:B() called.n;private:char *buf;void fun(A *a)delet

7、e a;void main()A *a=new B(15);fun(a);A:A() called.B:B() called.B:B() called.A:A() called.25 下面程序的運(yùn)行結(jié)果是_。#include int a =1,3,5,7,9;int *p =a,a+1,a+2,a+3,a+4;void main( )printf(%dt%dt%dn,a4,*(a+2),*p1);printf(%dt%dt%dn,*(p+1)+a2,*(p+4)-*(p+0),*(a+3)%a4);9 5 38 4 7二、 問答題(每小題5分,共20分)1若程序員沒有定義拷貝構(gòu)造函數(shù),則編譯器

8、自動(dòng)生成一個(gè)缺省的拷貝構(gòu)造函數(shù),它可能會(huì)產(chǎn)生什么問題?解答要點(diǎn):當(dāng)對(duì)象含有指針數(shù)據(jù)成員,并用它初始化同類型的另一個(gè)對(duì)象時(shí),缺省的拷貝構(gòu)造函數(shù)只能將該對(duì)象的數(shù)據(jù)成員復(fù)制給另一個(gè)對(duì)象,而不能將該對(duì)象中指針?biāo)赶虻膬?nèi)存單元也復(fù)制過去。這樣,就可能出現(xiàn)同一內(nèi)存單元釋放兩次,導(dǎo)致程序運(yùn)行出錯(cuò)。2 簡述成員函數(shù)、全局函數(shù)和友元函數(shù)的差別。解答要點(diǎn):以下幾點(diǎn)必須說清楚:成員函數(shù)是在類內(nèi)部定義的,作用域在類的內(nèi)部,成員函數(shù)可以訪問類的數(shù)據(jù)成員(公有、保護(hù)和私有數(shù)據(jù)成員),可以調(diào)用該類的其它成員函數(shù)(公有、保護(hù)和私有成員函數(shù)),可以調(diào)用全局函數(shù)。如果友元函數(shù)是另一個(gè)類的公有成員函數(shù),則該類的成員函數(shù)也只能通過那

9、個(gè)類的對(duì)象調(diào)用,不能調(diào)用那個(gè)類的保護(hù)和私有成員函數(shù)。非本類成員函數(shù)(其它類成員函數(shù)或全局函數(shù))可以通過該類的對(duì)象訪問該類的公有數(shù)據(jù)成員和調(diào)用該類的的公有成員函數(shù)。不是在類中定義的成員函數(shù)都是全局函數(shù)。如果某一個(gè)函數(shù)(全局函數(shù)或類的成員函數(shù))定義為另一個(gè)類的友元函數(shù),需要在那個(gè)類中用friend關(guān)鍵字聲明,友元函數(shù)并不是類的成員,它的定義自然是在那個(gè)類的外面。3 簡述結(jié)構(gòu)化的程序設(shè)計(jì)、面向?qū)ο蟮某绦蛟O(shè)計(jì)的基本思想。解答要點(diǎn):結(jié)構(gòu)化的程序設(shè)計(jì)將數(shù)據(jù)和對(duì)數(shù)據(jù)的操作分離,程序是由一個(gè)個(gè)的函數(shù)組成的,面向?qū)ο蟮某绦蛟O(shè)計(jì)將數(shù)據(jù)和操作封裝在一起,程序是由一個(gè)個(gè)對(duì)象組成的,對(duì)象之間通過接口進(jìn)行通信,它能夠較好

10、地支持程序代碼的復(fù)用。4 結(jié)構(gòu)struct和類class有什么異同?解答要點(diǎn):struct和class都可以定義類,但是缺省訪問權(quán)限說明時(shí),struct的成員是公有的,而class的成員是私有的。在C+中,struct可被class代替。三、找出下面程序(或程序段)中的語法錯(cuò)誤,并予以糾正(每小題4分,共8分)(1)程序功能是倒序輸出各給定的字符串。#include void main()char str5 =First,Second,Third,Forth,Fifth;char *cp =str4,str3,str2,str1,str0;int i;while(i=5)printf(%c ,

11、*(cp+i);i+; char str5 =First,Second,Third,Forth,Fifth;應(yīng)為char str510 =First,Second,Third,Forth,Fifth; while(i=5)應(yīng)為while(i5) printf(%c ,*(cp+i);應(yīng)為printf(%s,*(cp+i); int i;應(yīng)為int i=0;(2)程序功能是將各個(gè)平方根值放入數(shù)組中。#include void main()int max,a,i;scanf(%d%d,max,a);double xmax;for (i=0;imax;i+)xi=sqrt(a*i); 增加#incl

12、ude scanf(%d%d,max,a);應(yīng)為scanf(%d%d,&max,&a); double xmax;改為:double *x=new doublemax;delete x;四、(8分)下列shape類是一個(gè)表示形狀的抽象類,area( )為求圖形面積的函數(shù),total( )則是一個(gè)通用的用以求不同形狀的圖形面積總和的函數(shù)。請(qǐng)從shape類派生三角形類(triangle)、矩形類(rectangle),并給出具體的求面積函數(shù)class shape public: virtual float area( )=0; ;float total(shape *s ,int n) float

13、 sum=0.0; for(int i=0;iarea( ); return sum;class Triangle:public Shapepublic:Triangle(double h,double w)H=h;W=w;double Area() constreturn H*W*0.5;private:double H,W;class Rectangle:public Shapepublic:Rectangle(double h,double w)H=h;W=w;double Area()constreturn H*W;private:double H,W;五、(6分)完成順序查找函數(shù)f_

14、seq( )。其過程是:從表頭開始,根據(jù)給定的模式,逐項(xiàng)與表中元素比較。如果找到所需元素,則查找成功,并打印出它在表中的順序號(hào)。如果查找整個(gè)表仍未找到所需對(duì)象,則查找失敗#include void f_seq(char *list,char *object,int len)/list 指針數(shù)組,指向字符串/object 模式串/len 表的長度char *p;int strcmp(char *s,char *t);p=list;while (_) /plist+lenif (strcmp(*p,object)=0)break;else _; /p+if (pnext=NULLp=head-ne

15、xt;head-next=NULL;while(_) /p!=NULL或ptemp1=head;_; /head=p;temp2=p;p=p-next;_; /temp2-next=temp1;或head-next=temp1;/Match while statenmentreturn head; /返回逆置后的鏈表的頭結(jié)點(diǎn)一、 選擇填空題(共20小題,每小題2分,共40分)。1. 關(guān)于C+與C語言關(guān)系的描述中,( 4)是錯(cuò)誤的。 a.C語言是C+語言的一個(gè)子集 b.C語言與C+語言是兼容的 c.C+語言對(duì)C語言進(jìn)行了一些改進(jìn) d.C+語言和C語言都是面向?qū)ο蟮?按照標(biāo)識(shí)符的要求,(1 )符號(hào)

16、不能組成標(biāo)識(shí)符。 a.連接符 b.下劃線 c.大小寫字母 d.數(shù)字字符3. 為了避免嵌套的if-else語句的二義性,C語言規(guī)定else總是與( 3)組成配對(duì)關(guān)系。 a.縮排位置相同的if b.在其之前未配對(duì)的if c.在其之前未配對(duì)的最近的if d.同一行上的if4. 在int a 3=1,3,2,4,5,6,0;中,a22的值是( 3)。 a.1 b.0 c.6 d.25. 設(shè)char *s;,以下正確的表達(dá)式是(2)。 a.s=computer; b.*s=computer; c.*s=computer; d.*s=c;6. 對(duì)于int *pa5;的描述中,(4 )是正確的。 a.pa是

17、一個(gè)指向數(shù)組的指針,所指向的數(shù)組是5個(gè)int型元素 b.pa是一個(gè)指向某數(shù)組中第5個(gè)元素的指針,該元素是int型變量 c.pa 5表示某個(gè)元素的第5個(gè)元素的值 d.pa是一個(gè)具有5個(gè)元素的指針數(shù)組,每個(gè)元素是一個(gè)int型指針7. 在下列表示引用的方法中,(1 )是正確的。已知:int m=10; &x=m; &y=10; &z; d.float &t=&m;8. 下列for循環(huán)的次數(shù)為( 2)。for(i=0, x=0; !x&i=5; i+) a.5 b.6 c.1 d.無限9. 對(duì)于C/C+語言的函數(shù),下列敘述中正確的是(1)。 a.函數(shù)的定義不能嵌套,

18、但函數(shù)調(diào)用可以嵌套 b.函數(shù)的定義可以嵌套,但函數(shù)調(diào)用不能嵌套 c.函數(shù)的定義和調(diào)用都不能嵌套 d.函數(shù)的定義和調(diào)用都可以嵌套10. 在一個(gè)被調(diào)用函數(shù)中,關(guān)于return語句使用的描述,( 4)是錯(cuò)誤的。 a.被調(diào)用函數(shù)中可以不用return語句 b.被調(diào)用函數(shù)中可以使用多個(gè)return語句 c.被調(diào)用函數(shù)中,如果有返回值,就一定要有return語句 d.被調(diào)用函數(shù)中,一個(gè)return語句可以返回多個(gè)值給調(diào)用函數(shù)11. 在一個(gè)函數(shù)中,要求通過函數(shù)來實(shí)現(xiàn)一種不太復(fù)雜的功能,并且要求加快執(zhí)行速度,選用( 1)。 a.內(nèi)聯(lián)函數(shù) b.重載函數(shù) c.遞歸調(diào)用 d.嵌套調(diào)用12. 使用fseek函數(shù)可以實(shí)

19、現(xiàn)的操作是( 1)。 a.改變文件指針的當(dāng)前位置 b.文件的順序讀寫 c.文件的隨機(jī)讀寫 d.以上都不對(duì)13. 下列存儲(chǔ)標(biāo)識(shí)符中,( 3)的可見性與存在性不一致。 a.外部類 b.自動(dòng)類 c.內(nèi)部靜態(tài)類 d.寄存器類14. 在如下結(jié)構(gòu)定義中,不正確的是( 2)。 a.struct student int no; char name10;float score; b.struct stud20int no;char name10;float score; c.struct student int no; char name10;float score; stud20; d.structint n

20、o;char name10;float score;stud100 ;15. 將兩個(gè)字符串連接起來組成一個(gè)字符串時(shí),選用(3 )函數(shù)。 a.strlen( ) b.strcpy( ) c.strcat( ) d.strcmp( )16. ( 4)不是構(gòu)造函數(shù)的特征 a.構(gòu)造函數(shù)的函數(shù)名與類名相同 b.構(gòu)造函數(shù)可以重載 c.構(gòu)造函數(shù)可以設(shè)置缺省參數(shù) d.構(gòu)造函數(shù)必須指定類型說明17. 已知:類A中一個(gè)成員函數(shù)說明如下:void Set(A&a);其中,A&的含義是(3 )。 a.指向類A的指針為a b.將a的地址值賦給變量Set c.a是類A對(duì)象的引用,用來作函數(shù)Set()的參數(shù) d.變量A與a

21、按位與作為函數(shù)Set( )的參數(shù)18. 已知:print( )函數(shù)是一個(gè)類的常成員函數(shù),它無返回值,下列表示中,( 1)是正確的。 a.void print( ) const; b.const void print( ); c.void const print( ); d.void print(const);19. 關(guān)于虛函數(shù)的描述中,(3 )是正確的。 a.虛函數(shù)是一個(gè)static類型的成員函數(shù) b.虛函數(shù)是一個(gè)非成員函數(shù) c.基類中說明了虛函數(shù)后,派生類中將其對(duì)應(yīng)的函數(shù)可不必說明為虛函數(shù) d.派生類的虛函數(shù)與基類的虛函數(shù)具有不同的參數(shù)個(gè)數(shù)和類型20. 關(guān)于new運(yùn)算符的下列描述中,( 4)

22、是錯(cuò)的。 a.它可以用來動(dòng)態(tài)創(chuàng)建對(duì)象和對(duì)象數(shù)組 b.使用它創(chuàng)建的對(duì)象和對(duì)象數(shù)組可以使用運(yùn)算符delete刪除 c.使用它創(chuàng)建對(duì)象時(shí)要調(diào)用構(gòu)造函數(shù) d.使用它創(chuàng)建對(duì)象數(shù)組時(shí)必須指定初始值二、問答題(15分)1、 (3分)虛析構(gòu)函數(shù)有什么作用?2、 (3分)拷貝構(gòu)造函數(shù)在哪幾種情況下調(diào)用?3、 (4分)函數(shù)重載與函數(shù)覆蓋有什么不同,它們與多態(tài)有什么關(guān)系?4、 (3分)C+繼承是如何工作的?5、 (2分)類與對(duì)象有什么區(qū)別?三、(6分)分析下面程序的運(yùn)行結(jié)果#include class Bpublic:B()B(int i)b=i;virtual void virfun()coutB:virfun(

23、) called.n;private:int b;class D:public Bpublic:D()D(int i,int j):B(i)d=j;private:int d;void virfun()coutvirfun();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, argv;)char *str;int count=0;if(argc2)exit(1);str= ;while(*str)if(isalpha

24、( ) count+;printf(n字母?jìng)€(gè)數(shù):%dn,count);提示:int isalpha(int ch)函數(shù)功能是檢查ch是否是字母 五、(8分) 定義一個(gè)字符棧類Stack(包括類的實(shí)現(xiàn))。數(shù)據(jù)成員包括一個(gè)存放字符的數(shù)組stck 和一個(gè)棧指針tos。棧數(shù)組的尺寸由常量SIZE確定。棧的基本操作為Push()和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ù)。i

25、nt 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、D11、A 12、A 13、C 14、B 15、C 16、D 17、C 18、A 19、C 20、D二、問答題1、 虛析構(gòu)函數(shù)有什么作用?解答要點(diǎn):對(duì)象銷毀時(shí),需要調(diào)用析構(gòu)函數(shù)。在多態(tài)調(diào)用時(shí),是用基類的指針訪問派生類的對(duì)象。如果析構(gòu)函數(shù)是非虛函數(shù),則基類指針只能訪問基類的析構(gòu)函數(shù),而不能訪問派生類的析構(gòu)函數(shù),導(dǎo)致派生類對(duì)象銷毀時(shí),沒有調(diào)用派生類的析構(gòu)函數(shù),只是調(diào)用了基類的析構(gòu)函數(shù)。如果把析構(gòu)函數(shù)定義成虛函數(shù),則可克服這個(gè)問題。2

26、、 拷貝構(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ù)重載是指函數(shù)名相同,而函數(shù)的參數(shù)個(gè)數(shù)或類型不同;覆蓋是指在派生類中成員函數(shù)與基類成員函數(shù)的函數(shù)名、參數(shù)個(gè)數(shù)、類型與返回值均相同;C+中正是通過虛函數(shù)的覆蓋,實(shí)現(xiàn)多態(tài)的功能。4、 C+繼承是如何工作的?解答要點(diǎn):繼承使得派生類能夠使用基類的公有和保護(hù)成員,從而實(shí)現(xiàn)代碼的復(fù)用,派生類可以增加成員,也可以隱藏和覆蓋基類的成員。對(duì)于公有繼承,基類成員的訪問權(quán)限在派生類保持不變。5、 類與對(duì)象有什么區(qū)別?解答要點(diǎn):類是類型,是對(duì)象的抽象,對(duì)象是類的具體實(shí)例。一個(gè)類可以有多個(gè)對(duì)象,每個(gè)對(duì)象都有自己的存儲(chǔ)單元,而類不占存儲(chǔ)單元。三、運(yùn)行結(jié)果為: D:

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。

最新文檔

評(píng)論

0/150

提交評(píng)論