/*
* 程序的版权和版本声明部分
* Copyright (c)2013, 烟台大学计算机学院学生
* All rightsreserved.
* 文件名称:
* 作 者: 初瑞
* 完成日期: 2014年 4 月 8 日
* 版本号: 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)//求最大值,n为动态数组长度
{
int b=0;
len=n;//n为动态数组的长度
arrayAddr=new int[n];//对arrayAddr分配新的空间
for(int i=0;i<n;i++)
{
*(arrayAddr+i)=*(a+i);//将a指向的数组中的数值,逐个地复制到新分配的空间中,此处的a不能被n替代
if(*(arrayAddr+i)>b)
{
b=*(arrayAddr+i);
}
max=b;
}
}
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;
}
运算结果: