程式:
/*
* 下面的程式,因為存在指針類型的資料成員,需要能完成深複制的構造函數。請補充完整構造函數和析構函數(其他不必動)。
* 其中,構造函數要完成下面三個任務:
*(1)為各成員函數指派,其中arrayAddr應該是為儲存資料新配置設定的連續空間的首位址;
*(2)将a指向的數組中的數值,逐個地複制到新配置設定的空間中
*(3)getMax( )函數采取的政策是直接傳回max,計算max的工作,由構造函數完成
*/
#include<iostream>
using namespace std;
class A
{
private:
int *arrayAddr; //儲存一個有len個整型元素的數組的首位址
int len; //記錄動态數組的長度
int max; //動态數組中的最大值(并非動态數組中必須要的資料成員)
public:
A(int *a, int n);
~A();
int getValue(int i); //獲得a指向的數組中下标為i的元素的值
int getLen(); //傳回數組長度
int getMax( ); //傳回數組中的最大值
};
A::A(int *a,int n)
{
len=n;
arrayAddr=new int[n]; //沒太明白,照着項目一寫的
for(int i=0;i<n;i++)
{
arrayAddr[i]=a[i]; //複制數組
}
}
A::~A()
{
delete []arrayAddr;
}
int A::getValue(int i) //獲得a指向的數組中下标為i的元素的值
{
return arrayAddr[i];
}
int A::getLen() //傳回數組長度
{
return len;
}
int A::getMax( ) //傳回數組中的最大值
{
max=arrayAddr[0]; //以前用的,求出數組中的最大值
for(int i=1;i<len;i++)
{
if(arrayAddr[i]>max)
{
max=arrayAddr[i];
}
}
return max;
}
int main()
{
int b[10]= {75, 99, 90, 93, 38, 15, 5, 7, 52, 4};
A r1(b,10);
cout<<"最大值:"<<r1.getMax()<<endl;
int c[15] = {18,68,10,52,3,19,12,100,56,96,95,97,1,4,93};
A r2(c,15);
int i,s=0;
for(i=0; i<r2.getLen(); i++)
s+=r2.getValue(i);
cout<<"所有元素的和為:"<<s<<endl;
return 0;
}
結果:
![](https://img.laitimes.com/img/9ZDMuAjOiMmIsIjOiQnIsIiclRnblN0LclHdpZXYyd2LcBzNvwVZ2x2bzNXak9CX90TQNNkRrFlQKBTSvwFbslmZvwFMwQzLcVmepNHdu9mZvwFVywUNMZTY18CX052bm9CX90zdORTUE10MNpWT4FEVkZXUYpVd1kmYr50MZV3YyI2cKJDT29GRjBjUIF2LcRHelR3LcJzLctmch1mclRXY39zNzkDMxUjMwIDOwQDM0EDMy8CX0Vmbu4GZzNmLn9Gbi1yZtl2Lc9CX6MHc0RHaiojIsJye.jpg)
體會:一開始寫這道題的時候,老鼠啃天無處下嘴,試着寫函數的實作,又上面的題的根據深複制的寫法把這道題寫了,後來一看,并沒有自己想的那麼麻煩,就是不敢想,不敢做。。。後面這些知識學起來明顯深奧了,這是我們要成長為進階菜鳥了麼。。。