第六周项目二——我的数组类
来源:互联网 发布:魔百和网络机顶盒 编辑:程序博客网 时间:2024/06/06 05:33
下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:
(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;}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;}
参考解答:
/* Copyright (c) 2014, 烟台大学计算机学院 * All rights reserved. * 文件名称:test.cpp * 作者:陈丹妮 * 完成日期:2015年 4 月 14 日 * 版 本 号: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(a[i]>max) max=a[i]; //计算出数据中的最大值max }}MyArray::~MyArray(){ delete [] arrayAddr; //释放指针型数据a所指向的空间}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;}
知识点总结:1.用new分配了一个空间,记得一定要用delete释放,不然会使内存满盖。
2.释放的是一个内存空间 “释放指针型数据a所指向的空间”。
心得体会:多看看书,熟悉书中的知识,积蓄知识储备,继续加油!
0 0
- 第六周——项目二我的数组类
- 第六周项目二——我的数组类
- 第六周项目二——我的数组类
- 第六周项目二—我的数组类
- 15第六周项目二——我的数组类
- 第六周 课后实践:项目二——我的数组类
- 第六周项目二:我的数组类
- 第六周 项目二:我的数组类
- 第六周项目二:-我的数组类
- 第六周项目二我的数组类
- 第六周项目二--我的数组类
- 第六周 项目二-我的数组类
- 第六周 项目二--我的数组类
- 第六周项目二我的数组类
- 2015年第六周项目二:我的数组类
- 第六周项目二 我的数组类
- 第六周项目二 我的数组类
- 第六周项目二 我的数组类
- 有关Eclipse svn 插件的坑
- sqlite入门基础(二):sqlite3_get_table,sqlite3_free_table
- android 图片网络下载github开源框架之Universal-Image-Loader
- Android NDK开发
- ipv4---udp4.&.udp4lite
- 第六周项目二——我的数组类
- POJ3278 Catch That Cow BFS
- CTO WANTED(Shang Hai) 发个招聘信息
- 最小二乘法实现数据拟合
- L2---net_device---lwevent
- 【算法之链表(三)】单链表中,在仅允许使用一个指针的情况下,在指定的节点前面插入以及删除一个节点
- netfilter---(nf_hooks[][]).jpg
- GemU安装日志
- C++ 第二章编程题