- 1、本文档共7页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
编写一个使用类模板对数组中元素进行排序和求和的程序。【提示】在模板中完成排序和求和的操作。#includeiostreamusing namespace std;//类模板templateclass Tclass vector{ public: void sort(T a[],int n); T sum(T a[],int n); int search(T e, T a[], int n);};//排序templateclass Tvoid vectorT::sort(T a[],int n){ T temp; bool exchange; for(int i = 1; i n; i++) { exchange = false; for(int j = n-1; j = i; j--) if(a[j] a[j-1]) { temp = a[j]; a[j] = a[j-1]; a[j-1] = temp; exchange = true; } if(!exchange) return; }}//求和templateclass TT vectorT::sum(T a[],int n){ T sum = a[0]; for(int i = 1; i n; i++) sum += a[i]; return sum;}//查找templateclass Tint vectorT::search(T e, T a[], int n){ for(int i = 0; i n; i++) if(a[i] == e) return i; return -1;}void main(){ int data[5] = {5,4,3,2,1}; vectorint obj; cout数组和:obj.sum(data,5)endl; cout数字4数组位置:obj.search(4,data,5)endl; cout排序前数组各元素:endl; for(int i = 0; i 5; i++) coutdata[i] ; coutendl;}一、实验目的及要求学习完整的 C++程序开发过程。l 理解结构化程序设计的基本方法。l 掌握程序的三种基本控制结构及其语法。l 掌握 break、continue、goto 语句的执行过程并熟练使用。l 掌握标识符常量与变量的概念和定义方法。l 掌握各种运算符的功能、优先级和结合性。二、实验环境 DEV-C++三、实验内容设计一个数组类的模板,完成如下功能:(1)数组的规模可以任意类型,任意大小。(2)重载构造函数实现不同种的初始化方式(自拟)。(3)数组排序函数。(4)数组查找函数。(5)数组查找最大值/最小值函数。(6)对运算符[]重载,支持对该数组类模板对象的下标运算#include iostream#include typeinfo using namespace std; //模版类定义,一个是虚拟类型T,用来给定数组元素的类型,一个是整型值size,用来给定数组的大小,即元素个数//此类是一个万能数组,数组类型可以任意给定,数组大小可任意给定//模板类不仅可以传递类型T,也可以传递数值size template class T,int size class Array { public: Array() { int i; cout请输如size个typeid(T).name()值,对数组成员赋值:endl; for(i=0;isize;i++) //对数组元素值进行输入 cinarray[i]; } void display() { int i; cout输出size数组成员值:endl; for(i=0;isize;i++) //对数组元素值进行输出 coutarray[i] ; coutendl; } private: T array[size]; }; int main() { Arrayint,5
您可能关注的文档
- 第一篇 汽车概论.ppt
- SWD协议的研究和ARM程序下载器的设计.pdf
- 探索中学数学高效课堂及有效教学模式的研究.doc
- oracle查询3种方法.doc
- 肠道菌群及肠易激综合征关系的研究进展.doc
- 一节握手游戏课反思 曹瑞霞.doc
- FX2系列PLC的滤波与刷新时间调整.doc
- 软件工程模拟试卷与答案3.doc
- C语言期末测试试题和答案.doc
- 黑马程序员:必看文章:十四个方法告诉你怎样实现PHP性能全面优化.doc
- 2025下半年四川绵阳安州区考核招聘医疗卫生专业技术人员7人备考试题及答案解析.docx
- 2025年湖州安吉雷博人力资源服务有限公司公开招聘2人备考试题及答案解析.docx
- 2025年甘肃省酒泉市玉门市人民法院招聘司法辅助人员笔试参考题库附答案解析.docx
- 2025年黑龙江哈尔滨“丁香人才周”(春季) 卫生健康系统专项招聘1人备考试题及答案解析.docx
- 2025年湖南科技大学第一批高层次人才招聘50人备考试题及答案解析.docx
- 2025年湖南中医药大学招聘72人备考试题及答案解析.docx
- 2025年江苏扬州市宝应县教育系统事业单位面向乡村定向师范生招聘教师78人备考试题及答案解析.docx
- 2025年巢湖黄麓师范学校编外聘用教师招聘11人笔试参考题库附答案解析.docx
- 2025年福州市平潭综合实验区实发教育咨询有限公司2025年下半年幼儿园教师招聘笔试参考题库附答案解析.docx
- 2025下半年黑龙江科技大学招聘博士教师92人备考试题及答案解析.docx
文档评论(0)