我的数组类(深拷贝)

来源:互联网 发布:影响网络吞吐量的原因 编辑:程序博客网 时间:2024/06/05 22:54

请完成成员函数的定义,因为存在指针型的数据成员,注意需要深复制的构造函数。

#include<iostream>#include<string.h>using namespace std;class MyArray{private:    int *arrayAddr; //保存一个有len个整型元素的数组的首地址    int len;       //记录动态数组的长度    int max;       //动态数组中的最大值(并非动态数组中必须要的数据成员)public:    MyArray(int *a, int n);    ~MyArray();    int getValue(int i);   //获得数组中下标为i的元素的值    int getLen();          //返回数组长度    int getMax( );         //返回数组中的最大值};//写出各成员函数的定义 MyArray::MyArray(int *a,int n){len=n;arrayAddr=new int[n];for(int i=0;i<n;i++)arrayAddr[i]=a[i];}MyArray::~MyArray(){delete []arrayAddr;}int MyArray::getLen(){return len;}int MyArray::getMax(){max=arrayAddr[0];for(int i=1;i<len;i++){if(max<arrayAddr[i]){max=arrayAddr[i];}}return max;}int MyArray::getValue(int i){return arrayAddr[i];}int main(){    int b[10]= {75, 96, 90, 93, 38, 15, 5, 7, 52, 4};    MyArray 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};    MyArray r2(c,15);    int i,s=0;    for(i=0; i<r2.getLen(); i++)        s+=r2.getValue(i);    cout<<"所有元素的和为:"<<s<<endl;    return 0;}

运行结果:


在学习的过程中,也会难免一根筋,真的是自己想了好久都想不到,之前出现了一处错误:

自己还认为每一次循环后还把循环上面的那一句max=arrayAddr[0];也运行了,之后也是别人一眼就看出来了其实if条件语句每一次相比的其实不是最大的max,做了一个无用功,所以结果不正确。不懂就问真的是好习惯。

0 0
原创粉丝点击