第六周项目2-我的数组类
来源:互联网 发布:13年总决赛詹姆斯数据 编辑:程序博客网 时间:2024/05/17 04:13
下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:
(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;
(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;
(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;
(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;
(3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成)
/** Copyright (c) 2015,烟台大学计算机学院* All right reserved.* 作者:邵帅* 文件:Demo.cpp* 完成时间:2015年04月16日* 版本号:v1.0*/#include<iostream>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]; max=a[0]; for(int i=0; i<n; i++) { arrayAddr[i]=a[i]; if (max<a[i]) { max=a[i]; } }}MyArray::~MyArray(){ delete [] arrayAddr;}int MyArray::getValue(int i) //获得数组中下标为i的元素的值{ return arrayAddr[i];}int MyArray::getLen() //返回数组长度{ return len;}int MyArray::getMax( ) //返回数组中的最大值{ return max;}int main(){ int b[10]= {75, 99, 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;}运行结果:
@ Mayuko
0 0
- 第六周项目:我的数组类
- 第六周【项目2-我的数组类】2
- 第六周项目2 我的数组类
- 第六周 项目2-我的数组类
- 第六周 【项目2-我的数组类】
- 第六周项目2 我的数组类
- 第六周上机实践项目2-我的数组类
- 第六周【项目2-我的数组类】1
- 第六周 【项目2-我的数组类】
- 第六周项目2——我的数组类
- 第六周上机项目2我的数组类
- 第六周项目2 我的数组类
- 第六周项目2:我的数组类
- 第六周项目2-我的数组类
- 第六周项目2-我的数组类
- 第六周项目2我的数组类
- 第六周上机项目2 我的数组类
- 第六周项目二:我的数组类
- 图的割点与割边实现
- javaScript常用对象的--Date的用法
- 重定向小结
- OSGi
- java获取字母出现的次数
- 第六周项目2-我的数组类
- execl函数
- Light OJ 1129 Consistency Checker
- 2-12
- linux下代码生成core文件
- poj 3244
- linux内核部件分析之——设备驱动模型之class
- 出现"函数调用中缺少哨兵"的情况(execl)
- 裸机第一步,万能的神灯