实验6 题目.docVIP

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验6 题目

实验6 类与对象提高 【实验目的】 1、熟练使用类和对象,巩固静态数据成员、友元函数的应用; 2、掌握对象数组的用法; 3、掌握堆对象的用法; 4、理解子对象、对象指针、对象引用等概念; 5、会用类和对象解决应用问题。 【实验作业】 【题1】补充试题E:求几个学生分数的最大值。根据下面给出的部分代码和运行结果提示,自己完成算法,源程序名bc-e.cpp。不得改动给出的任何内容。【知识点:静态数据成员,友元函数】 (一)类Sample的定义: 数据成员: (1)姓名name,字符串; (2)分数score,浮点型; (3)静态数据成员m, 存放当前最大值 成员函数: 构造函数Sample(2个)、析构函数 ~Sample、 输出每个对象的姓名和分数的输出函数print、 求分数最大值的函数max; 输出分数最大值的友元函数printmax #includeiostream.h #includestring.h class Sample { public: //此处补充代码 friend void printmax(); //友元函数声明 private: char name[10]; float score; static float m; }; //此处补充代码 (二)main()函数 (1)定义a,b,c,d四个对象,其中: 对象a,b,c的初始值分别为 zhang,92.5、liu,100、sun,88 对象d为缺省初始值; (2)利用类的输出成员函数print分别输出对象a,b,c,d的姓名和分数值; (3)利用类的求最大值成员函数max求出对象a,b,c中的最大分数, 并利用成员函数printmax输出最大值 //自行编写主函数 运行结果提示: 【题2】习题7.5-2与6.5-3结合: 对象数组。要求类中含两个普通数据成员(姓名、成绩),一个或两个静态数据成员(总分、平均分),至少四个成员函数(构造、求总分和平均分、求最高成绩、打印学生信息)。源程序名为xt7.5-2.cpp。 【提示】可参考例7.6和例6.8。 求最高成绩所在下标的友元函数(也可用成员函数)参考: int fun(Student s[]) //形参为数组名,用对象指针也可。与实参可以同名。 { int k=0; //可增加max记最高分 for(int i=1;i5;i++) if(s[i].grades[k].grade) k=i; return k; } 学生原始数据参考: ① 姓名:李明, 成绩:89 ② 姓名:陈莉莉,成绩:95 ③ 姓名:王成, 成绩:78 姓名:宋鑫, 成绩:93 【选做】例题7.13用类来做:复数运算。创建一个名为Complex的类,进行复数的算术运算(加减乘除可任选几种),编写程序测试该类。源程序名为lt7.13-1.cpp。 【提示】(各标识符可不按以下指定的名字命名) 复数的形式为:实部+虚部*i 用浮点表示类中的私有成员: double real, imag; 给类提供一个能够对所声明的对象进行初始化的构造函数; Complex::Complex(double x, double y); 给类提供能够完成如下功能的公有成员函数: A)两个复数相加: void Complex::Addition(const Complex s,const Complex t); 即实部与实部相加,虚部与虚部相加;(亦可不用常引用,用较好。下同) B)两个复数相减: void Complex::Subtraction(const Complex s,const Complex t); 即被减数的实部减去减数的实部,被减数的虚部减去减数的虚部; C)两个复数相乘: void Complex::Multiplication(const Complex s,const Complex t); 假设两个复数为a+bi,c+di,最终两复数相乘后得数的实部=a*c-b*d,最终得数的虚部=a*d+b*c; D) 两个复数相除: void Complex::Division(const Complex s,const Complex t); 假设两个复数为a+bi,c+di,最终两复数相除后得数的实部=,虚部= E) 以 (a,b) 或 a+bi 的格式输出结果(a是实部,b是虚部): void Complex::Print( ); 缺省的姓名和分数

文档评论(0)

zijingling + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档