网站大量收购闲置独家精品文档,联系QQ:2885784924
  1. 1、本文档共10页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
C作业4

9-1 编写程序提示用户输入一个班级中的学生人数n,再依次提示用户输入n个人在课程A中的考试成绩,然后计算出平均成绩,显示出来。请使用本书第9章中的数组类模板Array定义浮点型数组存储考试成绩。 //array.h #ifndef ARRAY_CLASS #define ARRAY_CLASS #include iostream.h #include stdlib.h #ifndef NULL const int NULL = 0; #endif // NULL //错误类型集合,共有三种类型的错误:数组大小错误、内存分配错误和小标越界 enum ErrorType {invalidArraySize, memoryAllocationError, indexOutOfRange}; //错误信息 char *errorMsg[] ={ Invalid array size, Memory allocation error,Invalid index: }; //数组类模板定义 template class T class Array { private: T* alist; //T类型指针,用于存放动态分配的数组内存首地址 int size; //数组大小(元素个数) void Error(ErrorType error,int badIndex=0) const; // 错误处理函数 public: Array(int sz = 50); //构造函数 Array(const ArrayT A); //拷贝构造函数 ~Array(void); //析构函数 ArrayT operator= (const ArrayT rhs); //重载“=”使数组对象可以整体赋值 T operator[](int i); operator T* (void) const;//重载[]与T*,使Array对象可以起到C++普通数组的作用 int ListSize(void) const; // 取数组的大小 void Resize(int sz); // 修改数组的大小 }; //以下为类成员函数的实现 //模扳函数Error实现输出错误信息的功能 template class T void ArrayT::Error(ErrorType error, int badIndex) const { cout errorMsg[error]; //根据错误类型,输出相应的错误信息 // for indexOutOfRange, print the bad index if (error == indexOutOfRange) cout badIndex; //如果是下标越界错,输出错误的下标 cout endl; exit(1); } // 构造函数 template class T ArrayT::Array(int sz) { if (sz = 0) //sz为数组大小(元素个数),若小于0,则输出错误信息 Error(invalidArraySize); size = sz; // 将元素个数赋值给变量size alist = new T[size]; //动态分配size个T类型的元素空间 if (alist == NULL) //如果分配内存不成功,输出错误信息 Error(memoryAllocationError); } //析构函数 template class T ArrayT::~Array(void) { delete [] alist; } //复制构造函数 template class T ArrayT::Array(const ArrayT X) { int n = X.size; size = n; //从对象X取得数组大小,并赋值给当前对象的成员 //为对象申请内存并进行出错检查 alist = new T[n]; // 动态分配n个T类型的元素空间 if(alist == NULL) //如果分配内存不成功,输出错误信息 Error(memoryAllocationError); //从对象X复制数组元素到本对象 T* srcptr = X.alist; // X.alist是对象X的数组首地址 T* destptr = alist; // alist是本对象中的数组首地址 while (n--) // 逐个复制数组元素 *destptr++ = *srcptr++; } //重载“=”运算符rhs赋值给本对象,实现对象之间的整体赋值 template cla

文档评论(0)

638922bb + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档