第六周项目二 我的数组类
来源:互联网 发布:目标识别算法 编辑:程序博客网 时间:2024/05/18 01:54
问题及代码:
/** Copyright (c) 2014, 烟台大学计算机学院* All rights reserved.* 文件名称:test.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){len=n;arrayAddr=new int [n];arrayAddr=a; int i; max=-10000; for(i=0;i<n;i++) {if(arrayAddr[i]>max) max=arrayAddr[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;}
运行结果:
知识点总结:
深复制的时候注意不要建立野指针,并且建立的空间长度要符合要求,注意最后要将new建立的新空间释放
0 0
- 第六周项目二:我的数组类
- 第六周——项目二我的数组类
- 第六周 项目二:我的数组类
- 第六周项目二:-我的数组类
- 第六周项目二—我的数组类
- 第六周项目二我的数组类
- 第六周项目二--我的数组类
- 第六周 项目二-我的数组类
- 第六周 项目二--我的数组类
- 第六周项目二——我的数组类
- 第六周项目二我的数组类
- 2015年第六周项目二:我的数组类
- 第六周项目二 我的数组类
- 第六周项目二 我的数组类
- 第六周项目二 我的数组类
- 第六周项目二之我的数组类
- 第六周 项目二 我的数组类
- 第六周 项目二-我的数组类
- 初探Spring AOP
- linux命令(find中-a,-o,not的用法)
- 成员函数-求点类中距离-区别成员函数、友元函数和一般函数
- 我之前的博客地址
- 【LeetCode刷题记录】Merge Sorted Array
- 第六周项目二 我的数组类
- 第六周 程序阅读-深复制、友元、类模板(4)
- hibernate的主键生成策略
- 使用expdp(非本地)远程导出数据
- 第六周项目三人数不定的工资类
- 第六周阅读程序 (3)
- 第六周项目四 成员函数、友元函数和一般函数的区别
- 第五周项目一——深复制体验2
- 15第六周项目六——复数函数模板(2)