天天看點

項目二。深複制的構造函數

程式:

/*
*   下面的程式,因為存在指針類型的資料成員,需要能完成深複制的構造函數。請補充完整構造函數和析構函數(其他不必動)。
*   其中,構造函數要完成下面三個任務:
*(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;
}
           

結果:

項目二。深複制的構造函數

體會:一開始寫這道題的時候,老鼠啃天無處下嘴,試着寫函數的實作,又上面的題的根據深複制的寫法把這道題寫了,後來一看,并沒有自己想的那麼麻煩,就是不敢想,不敢做。。。後面這些知識學起來明顯深奧了,這是我們要成長為進階菜鳥了麼。。。

繼續閱讀