ImageVerifierCode 换一换
格式:DOCX , 页数:16 ,大小:20.26KB ,
资源ID:22567854      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/22567854.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(CPP实训4qRWord文件下载.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

CPP实训4qRWord文件下载.docx

1、【例4.5】 说明类A的功能:class A int x,y; void ask1(int a=0, int b=0); int ask2(); void ask3();;void A:ask1(int a, int b) x=a; y=b; int A:ask2() if (xy) return x; else return y;ask3() cout”x=”x”ty=”yendl;【解答】定义了一个类,类名为A,类A中有2个整型数据成员,它们都有私有数据;类A中有3个公有函数:ask1(int a=0, int b=0)、ask2()和ask3(),其中ask1(int a=0, int

2、b=0)实现将a的值赋给x,b的值赋给y,若参数b,或参数a、b空缺时,其默认值为0;ask2()是找出私有数据x、y中最大值,将这个最大值作为这个函数的返回结果;ask3()实现输出x和y。【例4.6】 说明类B的功能:class B void ask1(int, int b=0); void ask2();void B:ask1(int a, int b) x=b; y=a;ask2() int z; if (xy) z=x; x=y; y=z;【解答】定义了一个类,类名为B,类B中有2个整型数据成员x和y,它们都有私有数据;类B中有3个公有函数:ask1(int a, int b=0)、

3、ask2()和ask3(),其中ask1(int a, int b=0)实现将a的值赋给y,b的值赋给x,若参数b空缺时,b的默认值为0;ask2()是交换私有数据x、y中的值;【例4.7】 说明类C的功能:class C void ask(int, int); void ask(int); void ask();void C:ask(int a, int b) x=a;ask(int a) x=a;ask() cout【解答】定义了一个类,类名为C,类C中有2个整型数据成员x和y,它们都有私有数据;类C中有3个重载的公有函数:ask(int ,int)、ask(int)和ask(),其中as

4、k(int a, int b)实现将a的值赋给x,b的值赋给y;ask(int a)是将a的值赋给x;ask()实现输出x和y。【例4.8】 说明类D的功能:class D int x;float y; void ask(float);void D:ask(float b) y=b;【解答】定义了一个类,类名为D,类D中有2个数据成员x和y,它们都有私有数据,x为整型,y为实型;类D中有3个重载的公有函数:ask(int a)、ask(float b)和ask(),其中ask(int a)实现将a的值赋给x;ask(float b) 实现将b的值赋给y;【例4.9】 设计一个表示猫的类,包括猫

5、的颜色、体重、年龄等数据,具有设置猫的颜色,修改和显示猫的体重、年龄等操作。【解答】 设计猫类的类名为Cat,猫类Cat有3个数据成员,颜色用字符串color7,可以存放3个汉字,体重用实型数weight表示,年龄用整型数age表示,为了数据的安全性,Cat的3个数据成员全部为私有的。对猫的属性数据的设置和修改PutColor为设置和修改颜色,PutWeight为设置和修改体重,PutAge为设置和修改年龄,它们都设置为公有函数,还要有一个1次设置3个参数的函数SetCat。设计函数Display输出猫的信息。表示猫的类设计如下:class Cat int age; char color7;

6、float weight; void SetCat(char *s=”黄”, float w=1, int a=1); void PutColor(char *); void PutWeight(float ); void PutAge(int ); void Display(); void Cat:SetCat(char *s, float w, int a) /猫的默认颜色为黄、体重1kg、年龄1岁 age=a; weight=w; strcpy(color,s);PutColor(char *s) strcpy(color,s);PutWeight(float w) weight=w;P

7、utAge(int a) age=a;void Cat:Display() cout”n这只猫是一只”color”色的猫,” cout”体重”weight”千克,”年龄”age”岁。” 若猫的颜色是白色,重2.3kg,2岁,Display函数将会显示:这只猫是一只白色的猫,体重2.3千克,年龄2岁。【例4.10】 设计一个表示学习成绩的类,至少包括三门课程的成绩,可以设置、显示每门课程的成绩,可以计算、显示平均成绩。【解答】表示学习成绩的类简称为成绩类,设计成绩类的类名为Grade,成绩类Grade的数据成员,应该包括学生的学号和姓名,因为可能有重名的学生,所以用学号作为唯一代表一个学生的关键

8、字,假设学号全是9个字符,用字符串Number10表示,姓名最多为4个汉字,用字符串Name9表示, 可以存放4个汉字。假设有3门课,分别为C+程序设计语言,用整型变量Cpp表示;计算机原理,用整型变量Computer表示;数据库,用整型变量DataBase表示。平均成绩用实型变量Average表示。为了Grade类数据的安全性,数据成员全部为私有的,对成绩类的属性数据用一些函数进行设置和修改,PutNo为设置和修改学号,PutName为设置和修改姓名,PutCpp为设置和修改C+程序设计语言的成绩,PutCom为设置和修改计算机原理的成绩,PutData为设置和修改数据库的成绩,还有一个同时

9、设置所有5个参数的函数SetGrade,它们都设置为公有函数。计算平均成绩的函数为Calc,设计函数Display输出成绩。有时可能要查看某个学生的成绩,所以设计比较学号的函数为ComNo,设计比较姓名的函数为ComName, GetCpp为读取C+程序设计语言的成绩,GetCom为读取计算机原理的成绩,GetData为读取数据库的成绩,设计读取平均成绩的函数为GetAve。计算平均成绩只是在类的内部实现,所以设计为私有函数,其它函数都设计为公有函数。表示学习成绩的类设计如下:class Grade char Number10; char Name9; int Cpp, Computer, D

10、ataBase; float Average; void Calc();public: void PutNo(char *); void PutName(char *); void PutCpp(int x=60); void PutCom(int x=60); void PutData(int x=60); void SetGrade(char *s1=123456789, char *s2=李华, int x=60, int y=60, int z=60); int ComNo(char *); int ComName(char *); int GetCpp(); int GetCom()

11、; int GetData(); float GetAve();void Grade:PutNo(char *s) strcpy(Number,s);PutName(char *s) strcpy(Name,s);PutCpp(int x) Cpp=x; Calc(); /输入新数据就要计算平均值PutCom(int x) Computer=x;PutData(int x) DataBase=x;Calc() Average=(Cpp+Computer+DataBase)/3;SetGrade(char *s1, char *s2,int x, int y, int z) strcpy(Num

12、ber,s1); strcpy(Name,s2); Cpp=x; Computer=y; DataBase=z;int Grade:ComNo(char *s) return (!strcmp(Number,s);ComName(char *s)strcmp(Name,s);GetCpp() return Cpp;GetCom() return Computer;GetData() return DataBase;float Grade:GetAve() return Average;学号:Numbert;姓名:NameC+程序设计语言的成绩:Cpp计算机原理的成绩:Computer数据库的成

13、绩:DataBase平均成绩:Average4.2 建造集合类实训4.2.1 实训题目和要求设计一个表示整型数据的集合类,可以对集合中的数据进行添加、删除,可以判断一个整数是否在这个集合里,可以求出集合数据的多少,可以判断集合的空和满,空集合就是没有数据元素,满集合是数据元素已经占满给出的存储单元。两个集合可以做交运算,就是将两个集合的公共数据组成一个新的集合。两个集合可以做并运算,就是将两个集合的所有数据组成一个新的集合。实训目的是通过类实训学会用VC+编写类。实训要求:(1)分析集合类的数据属性要求。(2)分析集合类的操作属性要求。(3)编制集合类的接口定义。(4)实现集合类的属性函数。4

14、.2.2 实训参考步骤设计一个类,首先为类起一个有意义的名字,用集合的英文单词Set作为类名。接着分析类的数据成员,要实现整型数据的集合类,必须有存放整型数的地方,最方便的是定义一个整型数组,数组名为IntArrayN,最多可以存放N个整数,还要定义一个整型数Last表示已经存放的数据元素的个数。有趣的是下标小于Last的地方已经存储了数据,Last正好是可以存放新数据的第一个空位置,如图4.1所示。这里N要设计为常数。 IntArrayN 下标3614857697281 0 1LastN-1 图4.1 Set类中的数组结构添加新的数据Append,只要数组没有放满,就直接放到Last位置,再

15、将Last加1。删除数据Delete,如果要删除图4.1的最后一个81,只要将Last减1就行了,说明原来存放81的位置空了,可以再存放其它数据了,在C+中没有数据的物理删除,只是表明空或非空。如果要删除中间的数据,就把最后一个数据存入要删除数据的位置,然后将Last减1。若要删除57得到结果如图4.2所示。判断一个整数是否在这个集合中IsInSet,由整数与集合中的元素进行逐个比较来实现。集合空Empty时,Last=0;集合满Full时,Last=N。两个集合的交运算Intersect,是将两个集合的公共数据组成一个新的集合。两个集合的并运算Union,是将两个集合的所有数据组成一个新的集

16、合。Set类还要有一个初始化函数Init,给Last赋初值,就是Last=0。 图4.2 图4.1删除57后Set类中的数组结构下面实现Set类:先定义常量N。/先定义常量Nconst int N=1024; /假设最多存放1024个元素/定义类Setclass Set int IntArrayN; int Last; void Init(); int Append(int); int Delete(int); int Member(int); int Empty(); int Full(); void Intersect(Set); void Union(Set); void Display

17、();void Set:Init() Last=0;int Set:Empty() /判别集合是否空 if (Last=0) return 1; return 0;Full() /判别集合是否满 if (Last=N) return 1;Member(int x) /判别整数x是否在集合里 int i; for (i=0;iLast;i+) if (IntArrayi=x) return 1;Append(int x) /向集合中添加整数x if (Full() return 0; if (Member(x) return 1; /集合中已经有x IntArrayLast=x; Last+;

18、return 1; /插入xDelete(int x) /删除集合中的整数x if (IntArrayi=x) break; if (iLast)&(IntArrayi=x) IntArrayi=IntArrayLast-1; Last-; return 1;Intersect(Set s) /求2个集合的交集 int i,j;i+) for (j=0;js.Last;j+) if (IntArrayi=s.IntArrayj) break; if (js.Last)&(IntArrayi=s.IntArrayj) continue; Delete(IntArrayi); i-;Union(S

19、et s) /求2个集合的并集 Append(s.IntArrayi);Display() /显示集合中的所有元素IntArrayi if (i+1)%5=0) cout cout=Last表示没有找到,返回0。 Intersect(Set s) 函数实现 求2个集合的交集,一个是当前的集合,一个是集合s。“for (j=0;j+) if (IntArrayi=s.IntArrayj) break”语句对当前集合的元素IntArrayi查找在s集合中是否有相同的元素;if语句判别若当前集合的元素IntArrayi与s集合中的元素有相同的,则不做任何操作;否则,删除当前集合的IntArrayi元素,并且总元素数减1。 Union(Set s) 函数实现求2个集合的并集,一个是当前的集合,一个是集合s。for循环语句将s集合中的每个元素依次插入当前集合中。

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1