第六周 项目二
来源:互联网 发布:目标识别算法 编辑:程序博客网 时间:2024/05/21 08:35
【项目2-我的数组类】
下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:
(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;
(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;
(3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成)
下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:
(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;
(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;
(3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成)
/**Copyright (c)2014,烟台大学计算机与控制工程学院*All rights reserved.*dood luck*文件名称:d.cpp*作 者:张旺华*完成日期:2015年4月15日*版 本 号:v1.0**///(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;//(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;//3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成)#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( ); //返回数组中的最大值};int MyArray::getValue(int i){ //获得数组中下标为i的元素的值 return arrayAddr[i];}int MyArray::getLen(){ //返回数组长度 return len;}int MyArray::getMax( ) { //返回数组中的最大值 return max;}MyArray::MyArray(int *a, int n){ arrayAddr=new int[n]; len=n; max=a[0]; for(int i=0;i<n;i++) { max=(max<a[i]?a[i]:max); arrayAddr[i]=a[i]; }}MyArray::~MyArray(){ delete []arrayAddr;}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;}
在做这个程序犯了两个错误 1、析构函数忘了定义;2、建立动态数组的时候
arrayAddr=new int[n]; 在arrayAddr前面加了‘*’。不过慢慢改过来了。
0 0
- 第六周项目二。
- 第六周项目二
- 第六周 项目二
- 第六周 项目二
- 第六周项目二
- 第六周上机项目二
- 第六周项目二:填空
- 第六周项目二(1)
- 第六周项目二(2)
- 第六周项目二(b)
- 第六周项目一(二)
- 第六周项目二—数制转换
- 第六次实验:项目二
- 第六周项目二——指针填空A
- 第六周项目二—程序填空B
- 第六周项目二:指针访问对象(a)
- 第六周项目二(程序填空)---a和b
- 第六周 项目二:程序填空(a)
- Sorting Problem I NOJ1870 水 冒泡排序
- 第6周项目4
- 2015.4.15人数不定的工资类
- 第六周 项目1-2 深复制体验(2)
- 第6周项目1——深复制体验(3)
- 第六周 项目二
- ActionbarActivity上不显示menu
- 2015.4.15我的数组类
- 初探Spring AOP
- linux命令(find中-a,-o,not的用法)
- 成员函数-求点类中距离-区别成员函数、友元函数和一般函数
- 我之前的博客地址
- 【LeetCode刷题记录】Merge Sorted Array
- 第六周项目二 我的数组类