ARRAY&operator=(constARRAY&a);
friendARRAYoperator+(ARRAY&a,ARRAY&b);
friendostream&operator<<(ostream&os,ARRAY&a); };
ARRAY::ARRAY(constARRAY&a)
{ //**2**
for(inti=0;i p[i]=a.p[i]; } int&ARRAY::operator[](inti) { //**3** { cout<<"越界訪問!"; exit(0); } returnp[i]; } ARRAY&ARRAY::operator=(constARRAY&a) { num=a.num; p=newint[num]; for(inti=0;i p[i]=a.p[i]; //**4** } ARRAYoperator+(ARRAY&a,ARRAY&b) { if(a.num!=b.num) { cout<<"數(shù)組長度不相同!"< exit(0); } ARRAYt(a.num); for(inti=0;i t.p[i]=a.p[i]+b.p[i]; returnt; } ostream&operator<<(ostream&os,ARRAY&a) { inti=0; for(;i { cout< if(!((i+1)%10))cout< returnos; } voidmain() { ARRAYa(3); a[0]=a[1]=a[2]=3; cout<<'a'<
ARRAYb(a); cout<<'b'<
ARRAYc(2); c=a+b+b; cout<<'c'< c=((b=(a+b))+c); cout<<'a'<
a[7]=3; cout<
【參考答案】 (1)if(i<=0) (2)num=a.num; p=new int[num]; (3)if(i>=num||i<0) (4)return *this; 【試題解析】 主要考查對一個特殊的類--安全數(shù)組的掌握,其中涉及了友元函數(shù)、重載函數(shù)等,其中(2)中必需申請新的空間,這樣可以使得兩個對象分別占用不同的兩個空間,在自動調(diào)用析構(gòu)函數(shù)時不會遇到重復(fù)刪除的問題,這種方法要掌握。
計(jì)算機(jī)等級考試二級VB上機(jī)試題及答案匯總
計(jì)算機(jī)等級考試二級VB模擬試題及答案匯總
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |