面向对象程序设计(C++)实验一--类和对象.pdfVIP

面向对象程序设计(C++)实验一--类和对象.pdf

  1. 1、本文档共13页,可阅读全部内容。
  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文档。上传文档
查看更多

实验一类和对象

一、实验目的:

掌握类的设计和对象的创建及相关知识点如对象数组、类聚合、友元函数、静态

成员。

二、实验内容:

1、设计圆类,求两个圆的位置关系;

2、设计圆类和直线类,求直线与圆的位置关系;

3、设计学生类,求某班学生成绩的最高分、最低分及平均分;

4、设计部门类和教师类,其中部门类成员为教师类的子对象;

5、设计家庭银行账户类,其中账户资金为静态数据成员,为家庭成员共享;

6、设计复数类,友元函数实现复数的加减。

三、实验过程:

1、根据实验题目确定需要设计哪些类、各类中包含哪些数据成员和函数成员,

设计各成员的访问权限,设计数据成员的数据类型,设计函数成员的函数

原型;

2、给出类设计的程序实现,特别要注意重载构造函数的实现;

3、在主函数中完成题目中的逻辑,一般情况下需要创建相关类的对象,通过

对象对成员函数的调用或者通过对象指针对成员函数的调用完成相应的

功能。

四、参考程序代码:

1、设计圆类,求两个圆的位置关系

#includeiostream

#includemath.h

usingnamespacestd;

classCircle

{

private:

floata,b,r;

public:

Circle(floatc,floatd,floate)

{

a=c;

b=d;r=e;

}

friendvoidposition(Circle,Circle);

};

voidposition(Circlec1,Circlec2)

{

floatn,m,p;

p=sqrt((c1.a-c2.a)*(c1.a-c2.a)+(c1.b-c2.b)*(c1.b-c2.b));

n=fabs(c1.r-c2.r);

m=c1.r+c2.r;

if(pm)if(pm)

相离相离

if(p==m)if(p==m)

相切相切

if(pm)if(pm)

相交相交

}

intmain()

{

floata,b,c,d,e,f;

cinabcdef;

Circlec1(a,b,c),c2(d,e,f);

position(c1,c2);

return0;

}

运行结果:

2、设计圆类和直线类,求直线与圆的位置关系

#includeiostream

#includemath.h

usingnamespacestd;

classCircle//圆类

{private:

floatx,y,r;

public:

Circle(floata,floatb,floatc)

{x=a;y=b;r=c;}

floatgetx(){returnx;}

floatgety(){returny;}

floatgetr(){returnr;}

};

classLine//直线类

{private:

floata,b,c;

public:

Line(floatx,floaty,floatz)

{a=x;b=y;c=z;}

voidposition(Circlec1)

{

floatd=fabs(a*c1.getx()+b*c1.gety()+c)/sqrt(a*a+b*b);//

圆心到直线的距离

if(dc1.getr())if(dc1.getr())

相交相交

if((d-c1.getr())0.000001)if((d-c1.getr())0.000001)

相切相切相

文档评论(0)

157****9805 + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档