第六周 项目2-我的数组类
来源:互联网 发布:创业 知乎 编辑:程序博客网 时间:2024/05/20 09:26
/* * Copyright (c) 2014, 烟台大学计算机学院 * All rights reserved. * 文件名称:test.cpp * 作 者:呼亚萍 * 完成日期:2015年4月12日 * 版 本 号:v1.0 * * 问题描述:下面的程序,因为存在指针类型的数据成员,需要能完成深复制的构造函数。请补充完整构造函数和析构函数(其他不必动)。其中,构造函数要完成下面三个任务:(1)为各成员函数赋值,按照深复制原则,其中arrayAddr应该是为保存数据新分配的连续空间的首地址;(2)MyArray(int *a, int n)中,要将a指向的数组中的数值,逐个地复制到新分配的arrayAddr指向的空间中;(3)getMax( )函数采取的策略是直接返回max(所以,计算max的工作,由构造函数完成) * 程序输入:相应的程序 * 程序输出:对应得结果 */#include <iostream>using namespace std;class MyArray{public: MyArray(int *a,int n); ~MyArray(); int getValue(int i);//或得数组中下标为i的元素的值 int getLen();//返回数组长度 int getMax();//返回数组中的最大值private: int *arrayAddr;//保存一个有len个整型元数的数组的首地址 int len;//记录动态数组的长度 int max;//动态数组中的最大值};MyArray::MyArray(int *a,int n){ len=n; arrayAddr=new int[n]; arrayAddr=a; max= arrayAddr[0]; for(int i=0; i<n; i++) { if( arrayAddr[i]>max) max= arrayAddr[i]; }}MyArray::~MyArray(){ delete []arrayAddr;}int MyArray::getValue(int 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,4,1,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;}
运算结果:
知识点总结:
为arrayAdrr指针分配空间
学习心得:
每个人有不同的思路,要勇于尝试,加油!
0 0
- 第六周项目:我的数组类
- 第六周【项目2-我的数组类】2
- 第六周项目2 我的数组类
- 第六周 项目2-我的数组类
- 第六周 【项目2-我的数组类】
- 第六周项目2 我的数组类
- 第六周上机实践项目2-我的数组类
- 第六周【项目2-我的数组类】1
- 第六周 【项目2-我的数组类】
- 第六周项目2——我的数组类
- 第六周上机项目2我的数组类
- 第六周项目2 我的数组类
- 第六周项目2:我的数组类
- 第六周项目2-我的数组类
- 第六周项目2-我的数组类
- 第六周项目2我的数组类
- 第六周上机项目2 我的数组类
- 第六周项目二:我的数组类
- Android SQLite数据库使用INTO子句创建新表时报错
- Xilinx 移位寄存器 SRL16
- 浅谈 Python 的 with 语句
- 对模式图及通知的理解
- csdn上的markdown使用总结
- 第六周 项目2-我的数组类
- LeetCode - Longest Palindromic Substring
- 第六周 阅读程序(3)
- 如何计算一个集合的幂集
- C语言基础测试题
- Cocos2d-3.x_基本数据类型(cocos2d::Value)
- 初学ucosII(二)
- R.java was modified manually! Reverting to generated version!(R文件丢失异常原因汇总)
- Fisher准则线性分类器的Python实现