天天看點

第七周項目2-類内深複制

/*
*程式的版權和版本聲明部分:
*Copyright(c)2014,煙台大學計算機學院學生
*All rights reserved.
*檔案名稱:
*作者:田成琳
*完成日期:2014  年 4 月 7 日
*版本号:v1.0
*對任務及求解方法的描述部分:
*輸入描述:無
*問題描述:下面的程式,因為存在指針類型的資料成員,需要能完成深複制的構造函數。
      補充完整構造函數和析構函數(其他不必動)。其中,構造函數要完成下面三個任務:
  (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)
{
	max=-9999;
	len=n;
	arrayAddr=new int[n];
	for(int i=0;i<n;i++)
	{
		*(arrayAddr+i)=*(a+i);
		if(*(arrayAddr+i)>max)
		    max=*(arrayAddr+i);
	}
}
A::~A()
{
	delete arrayAddr;
}
int A::getValue(int i)
{   //獲得a指向的數組中下标為i的元素的值
    return arrayAddr[i];
}
int A::getLen()
{   //傳回數組長度
    return len;
}
int A::getMax( )
{  //傳回數組中的最大值
    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;
}
           

運作結果:

第七周項目2-類内深複制

心得體會:老師寫出的程式架構就是不一樣,條理分明,邏輯很好,整個大局觀念很強。自己寫出的還是不行。

繼續閱讀