MATLA第6次实验报.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验报告 实验目的 通过这些题目的训练,需要掌握静态数据成员以及静态成员函数的使用方法,友元函数的使用,以及掌握构造函数和析构函数,拷贝构造函数、内联成员函数、聚集的使用,熟练的使用类解决问题。 实验环境 编译器:Visual c++6.0 操作系统:Windows XP 三、实验题目 基础题1: 题目:定义一个Cat类,拥有静态数据成员HowManyCats,记录Cat的个体数目;静态成员函数GetHowMany(),存取HowManyCats。设计程序测试这个类,体会静态数据成员和静态成员函数的用法。 分析:定义一个名为Cat类,静态数据成员HowManyCats,记录Cat的个体数目,静态成员函数GetHowMany(),输入一只Cat的名字就让HowManyCats加1,调用静态成员函数GetHowMany()输出数目即可。 核心代码: #includeiostream using namespace std; class Cat//定义一个Cat类 { public: Cat(char Name)//定义一个构造函数,形参为Cat的名字 { CatName=Name; HowManyCats++; } static void GetHowMany() { coutthe number of cats: HowManyCatsendl; } private: char CatName; static int HowManyCats; }; int Cat::HowManyCats=0;//静态数据成员声明 void main() { char _name; int W=0; do { coutplease input the name of one cat(一个字母):endl; cin_name; W=1; Cat c(_name); coutif you want to contiue to input cat,please input 0 or else input 1.endl; cinW; }while(W==0); Cat::GetHowMany();//静态成员函数调用 } 程序运行及截图: 总结:掌握静态成员函数的定义与实现,以及静态数据成员的声明、定义和初始化方法,学会使用类解决实际问题。 基础题2: 题目:设计一个点(point)类, 1)在点类中设计友员函数,求两点间的距离。 2)设计一个线段(line)类。 分析:定义一个Point类,在其中设置一个友元函数求两点的距离,以及定义一个Line类用Point类型的数据成员求其长度,即求两点的距离。 核心代码: #includeiostream #includemath.h using namespace std; class Point//定义一个Point类 { public: Point(double NewX=0.0,double NewY=0.0) { x=NewX; y=NewY; } double GetX() { return x; } double GetY() { return y; } friend double dist(Point p1,Point p2);//友元函数声明 private: double x,y; }; double dist(Point p1,Point p2)//友元函数实现 { double x=p1.x-p2.x; double y=p1.y-p2.y; return static_castdouble ( sqrt (x*x+y*y)); } class line//定义一个线段类 { public: line(Point Np1,Point Np2); double getlen() { return len; } private: Point p1,p2; double len;//长度 }; line::line(Point Np1,Point Np2):p1(Np1),p2(Np2)//构造函数求线段长度 { double x=static_castdouble(p1.GetX()-p2.GetX()); double y=static_castdouble(p1.GetY()-p2.GetY()); len=sqrt(x*x+y*y); } void main() { double x1,y1,x2,y2; coutplease input two points(x1,y1,x2,y2):endl; cinx1y1x2y2; Point myp1(x1,y1),myp2(x2,y2);//构造两个点 coutthe distant is: ; coutdist(myp1,

文档评论(0)

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

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

1亿VIP精品文档

相关文档