第6周项目2-我的数组类
来源:互联网 发布:ubuntu安装mysql失败 编辑:程序博客网 时间:2024/05/16 19:16
/* * Copyright (c) 2015, 烟台大学计算机学院 * All rights reserved. * 文件名称:test.cpp * 作 者:刘畅 * 完成日期:2015年 4 月 11 日 * 版 本 号:v1.0 * * 问题描述: 下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;(3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成)。 * 输入描述:NULL; * 程序输出:按要求输出。
代码如下:
#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]; }}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;}
运行结果:
知识点总结:
对象的动态建立和释放。
0 0
- 第6周项目2我的数组类
- 第6周项目2-我的数组类
- 第6周项目2-我的数组类
- 第6周项目2-我的数组类
- 2015-第6周项目2-我的数组类
- 第6周项目2我的数组类
- 第6周项目我的数组类
- 第6周项目-我的数组类
- 第6周项目1-我的数组类
- 第5周项目2-我的数组类
- 第9周-项目2-我的数组类
- 第9周项目2:我的数组类
- 第9周项目2 我的数组类
- 第9周项目2-我的数组类
- 第9周项目2—我的数组类
- 第9周项目2-我的数组类
- 第9周项目2- 我的数组类
- 第9周项目2-我的数组类
- 第一章第七题
- spring单例和多例详解。如何在单例中调用多例对象
- mysql中利用DATE_FORMAT方法 实现统计每日/每月的新增用户
- 一个错误信息提示页面
- 【jquery事件对象event】| jqeury bind 绑定事件与 unbind删除绑定事件| pageX pageY
- 第6周项目2-我的数组类
- 算法复习(1) 堆排序
- Search in Rotated Sorted Array
- Rotate Array--LeetCode
- MySQL执行计划解读
- web项目之BBS发布至新浪云配置修改以及sql语句修改问题小结
- Java设计模式——依赖倒转原则
- java中IO类的各种操作
- pat中文练习题:简单题:1001. 害死人不偿命的(3n+1)猜想