【參考答案】
(1)將class D2:public Base
改為:class D2:virtual public Base
(2)將class D3::public D1,public D2
改為:class D3:public D1,public D2
(3)將d.f();改為:d.Base::f();
【試題解析】
(1)主要考查對(duì)虛基類(lèi)的理解,虛基類(lèi)可以解決二義性的問(wèn)題,其定義方式是在繼承列表中使用virtual關(guān)鍵字,使用虛基類(lèi)可以避免程序運(yùn)行中對(duì)基類(lèi)函數(shù)調(diào)用的不惟一;
(2)主要考查對(duì)類(lèi)的定義方法的掌握,“::”為作用域符,此處應(yīng)該使用“:”,因?yàn)楹竺媸抢^承列表;
(3)主要考查對(duì)虛基類(lèi)函數(shù)調(diào)用過(guò)程的理解,只有使用"::"限定才能訪(fǎng)問(wèn)基類(lèi)函數(shù),否則將會(huì)調(diào)用自身的函數(shù),如果該類(lèi)沒(méi)有該函數(shù)的定義,則會(huì)自動(dòng)調(diào)用其父類(lèi)的該函數(shù),所以必須使用“::”符號(hào)。
二、簡(jiǎn)單應(yīng)用題
請(qǐng)編寫(xiě)一個(gè)函數(shù)inlinelongsum(intn),用遞歸函數(shù)完成運(yùn)算:sum(n)=1*1+2*2+???+n*n,遞歸表達(dá)式為sum(n)=sum(n-1)+n2。
注意:部分源程序已存在文件kt10_2.cpp中。
請(qǐng)勿修改主函數(shù)main和其他函數(shù)中的任何內(nèi)容,僅在函數(shù)sum的花括號(hào)中填寫(xiě)若干語(yǔ)句。
文件kt10_2.cpp的內(nèi)容如下:
#include
inlinelongsum(intn)
{
}
voidmain()
{ intn;
cout<<"輸入n:";
cin>>n;
cout<<"結(jié)果為:"< 【參考答案】 inline long sum(int n) { if(n==1) return 1; else return n*n+sum(n-1); } 【試題解析】 本題考查對(duì)遞歸函數(shù)掌握的熟練程度。遞歸的終止條件為n=1時(shí),值為1。
計(jì)算機(jī)等級(jí)考試二級(jí)VB上機(jī)試題及答案匯總
計(jì)算機(jī)等級(jí)考試二級(jí)VB模擬試題及答案匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |