第 1 頁:選擇題 |
第 5 頁:基本操作題 |
第 6 頁:綜合應用題 |
四、綜合應用題
43請使用VC6或使用【答題】菜單打開考生文件夾proj3下的工程proj3,其中聲明的CDeepCopy是一個用于表示矩陣的類。請編寫這個類的賦值運算符成員函數0perator=,以實現深層復制。
要求:
補充編制的內容寫在“//************333************”與“//****************666*************”之間。不得修改程序的其他部分。
注意:程序最后將結果輸出到文件out.dat中。輸出函數writeToFile已經編譯為obj文件,并且在本程序中調用。
//CDeepCopy.h
#include
#include
using namespace std;
class CDeepCopy
{
public:
int n;//動態數組的元素個數
int *p;//動態數組首地址
CDeepCopy(int);
~CDeepCopy();
CDeepCopy&operator=(const CDeepCopy&r);//賦值運算符函數
};
void writeToFile(char});
//main.cpp
#include”CDeepCopy.h”
CDeepCopy::一CDeepCopy(){delete[]P;}
CDeepCopy::CDeepCopy(int k){n=k;p=new int[n];}//構造函數實現
CDeepCopy&CDeepCopy::0perator=(const CDeepCopy&r)//賦值運算符函數實現
{
//***********333*********
//***********666***********
}
int main()
{
CDeepCopy a(2),d(3);
a.p[O]=1;d.p[O]=666;//對象a,d數組元素的賦值
{
CDeepCopy b(3);//調用賦值運算符函數
a.p[O]=88;b=a;
cout<
}
cout<
cout<<”d fade away;\n”;
cout<
writeToFile(””);
return 0;
}
參考解析:
lq=r.n;//把對象r字符長度賦值給n
delete[]P;//刪除動態數組P
P=new int[n];//給動態數組P分配空間為n
for(int i=0;i
//遍歷對象r中的數組P
P[i]=r.P[i];//把r.P[i]賦值給P[i]
retum*this://返回被賦值的對象
相關推薦:
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內蒙古 |