- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
C++程序设计报告.doc
成绩
课程名称: C++ 课程设计 设计题目: 编写程序提示用户输入一个班级中的学生人数n,再依次提示用户输入n个人在课程A中的考试成绩,然后计算出平均值,显示出来。 要求用到第九章中的数组类模板 Array定义浮点型数组存储考试成绩。
姓 名: 石东梅 学 号: 1108020102 专业班级: 网络1101 班 完成日期: 20012 年 6 月 27日 1 设计任务
编写程序提示用户输入一个班级中的学生人数n,再依次提示用户输入n个人在课程A中
的考试成绩,然后计算出平均值,显示出来。要求用到第九章中的数组类模板Array定义浮点型数组存储考试成绩。
1.1 设计目的
(1)、加强C++课程学习,将课本上的理论知识运用于实践,通过实际的程序操作来提高自己编写程序的能力,达到理论与实践相结合的目的。
(2)、培养自己动脑思考,动手操作的能力,在实际操作过程中体会C++中面向对象的思想。
(3)、在实际的操作过程中去衡量自己理论知识掌握的程度,通过设计流程,编写程序,上机调试去寻找并发现知识的缺陷,并想办法弥补。
(4)、在本程序中主要是要达到能对类的定义及用法,数组的定义及用法,数组类模版,运算符重载,多文件结构,成员函数的实现等的熟练运用。
1.2设计内容
用数组类模板、析构函数、构造函数 、赋值构造函数、运算符重载、指针等语法来完成一个班级在某门课程中考试的平均值的程序。
1.3设计指标或者要求
设计指标:用C++完成一个班级在某门课程中的成绩储存并计算平均值的程序,要求用 到数组类模板。
输入要求:在程序运行的页面根据提示输入班级学生人数n,再依次输入每个人在课程A中的成绩。
输出要求:输出n个人在课程A中的平均成绩。
2 设计过程
、分析程序的功能:使用户能根据程序提示输入班级学生人数n和n个人在某门课中考试成绩,并能储存成绩然后计算平均值,显示出来。
、思考程序要用到的算法原理:使用数组类模板定义浮点型数组存储考试成绩;利用班级总人数与其在课程A中的总分之比的原理求平均值。
、设计程序流程图(见2.3)。
、编写程序(见2.4)。
2.1 程序功能
使用户能根据程序提示输入班级学生人数n和n个人在某门课中考试成绩,并能储存成绩然后计算平均值,显示出来。
2.2算法原理
(1)、使用数组类模板定义浮点型数组存储考试成绩;
(2)、利用班级总人数与其在课程A中的总分之比的原理求平均值。
2.3程序流程图
2.4 程序主要模块或者函数
#ifndef ARRAY_H
#define ARRAY_H
#include iostream.h
#include stdlib.h
#ifndef NULL
const int NULL = 0;
#endif
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;
int ListSize(void) const;
void Resize(int sz);
};
//以下为类成员函数的实现
template class T
void ArrayT::Error(ErrorType error, int badIndex) const
{
cout errorMsg[error];
if (error == indexOutOfRange)
cout badIndex;
您可能关注的文档
最近下载
- TZS 0678—2025《生物安全实验室工作人员本底血清样本管理规范》(水印版).pdf VIP
- 2025年工会基础知识考试题库及参考答案(通用版).pptx VIP
- 抗菌药物的合理使用课件(共37张PPT).pptx VIP
- 急危重症患者护理抢救流程与规范.pptx VIP
- 平衡梁组件的承压检测装置.pdf VIP
- 2025年最新工会基础知识考试题库及参考答案(通用版).pptx VIP
- 44-无机复合聚苯不燃保温板应用技术规程T_CIEEMA002-2020.pptx VIP
- 供货方案及质量保证措施 .docx VIP
- 殡葬领域突出问题专项整治行动实施方案.docx VIP
- T_ACEF 207—2025(工业有机废气收集系统技术规范).pdf
文档评论(0)