十一.3 点类派生直线类
来源:互联网 发布:led屏幕软件设置 编辑:程序博客网 时间:2024/05/19 13:56
/**程序的版权和版本声明部分:*Copyright(c)2014,烟台大学计算机学院学生*All rights reserved.*文件名称:*作者:cxz*完成日期:2014 年 5 月 13 日*版本号:v1.0*对任务及求解方法的描述部分:*输入描述:无*问题描述:定义点类Point,并以点类为基类,派生出直线类Line, 从基类中继承的点的信息表示直线的中点。*程序输出:点的信息和线的信息*问题分析:*算法设计:*/#include<iostream>#include<Cmath>using namespace std;class Point //定义坐标点类{public: Point():x(0),y(0) {}; Point(double x0, double y0):x(x0), y(y0) {};double getX(){return x;}double getY(){return y;} void PrintPoint(); //输出点的信息protected: double x,y; //点的横坐标和纵坐标};void Point::PrintPoint(){ cout<<"Point: ("<<x<<","<<y<<")"<<endl; //输出点}class Line: public Point //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点{public: Line(Point pts, Point pte); //构造函数,用初始化直线的两个端点及由基类数据成员描述的中点 double Length(); //计算并返回直线的长度 void PrintLine(); //输出直线的两个端点和直线长度private: class Point pts,pte; //直线的两个端点,从Point类继承的数据成员表示直线的中点};int main(){ Point ps(-2,5),pe(7,9); Line l(ps,pe); cout<<"About the Line: "<<endl; l.PrintLine(); //输出直线l的信息:两端点及长度 cout<<"The middle point of Line is: "; l.PrintPoint(); //输出直线l中点的信息 return 0;}Line::Line(Point pts,Point pte):Point((pts.getX()+pte.getX())/2,(pts.getY()+pte.getY())/2){this->pts=pts;this->pte=pte;}double Line::Length(){return sqrt(pow((pts.getX()-pte.getX()),2)+pow((pts.getY()-pte.getY()),2));}void Line::PrintLine(){cout<<"1st ";pts.PrintPoint();cout<<"2nd ";pte.PrintPoint();cout<<"The Length of Line "<<Length()<<endl;}
成果展示:
0 0
- 十一.3 点类派生直线类
- 点派生类直线
- 点派生直线类
- 项目3 - 点类派生直线类
- 项目3 点类派生直线类
- 11-3 点类派生直线类
- 项目3-点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 11-3 点类派生直线类
- android环境搭建+ant打包
- linux下杀死进程(kill)的N种方法
- 跟着Kuangbin学插头DP
- AFNetworking的使用
- 十一.3 点类派生直线类
- Oralce 常用命令
- LUA语言基础
- 致垂直电商们:谁无暴风劲雨时,守得云开见月明
- 熊猫成长史
- 4.7 INstance-Based Learning ,关于K近邻算法
- 干货系列1:Java互联网网站开发工程师 的技术提高与晋升路线(技术专精)
- HBase数据查询之Coprocessor
- 12周【项目1 - 长颈鹿类对动物类的继承】