第十一周项目3 - 点类派生直线类
来源:互联网 发布:网络推广这工作靠谱吗 编辑:程序博客网 时间:2024/06/05 00:30
问题及代码:/* *Copyright (c) 2015,烟台大学计算机学院*All rights reserved.*文件名称:test.cop*作者:*完成日期:2015年5月24日*版本号:v1.0**问题描述: *输入描述:*输出描述:
#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<<")"; //输出点}class Line: public Point //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点{public: Line(Point pts, Point pte); //构造函数,用初始化直线的两个端点及由基类数据成员描述的中点 double Length(); //计算并返回直线的长度 void PrintLine(); //输出直线的两个端点和直线长度private: class Point pts,pte; //直线的两个端点};//构造函数,分别用初始化直线的两个端点及由基类数据成员(属性)描述的中点Line::Line(Point pt1, Point pt2):Point((pt1.getX()+pt2.getX())/2,(pt1.getY()+pt2.getY())/2){ pts=pt1; pte=pt2;}double Line::Length() //计算并返回直线的长度{ double dx = pts.getX() - pte.getX(); double dy =pts.getY() - pte.getY(); return sqrt(dx*dx+dy*dy);}void Line::PrintLine(){ cout<<" 1st "<<endl; pts.PrintPoint(); cout<<" 2nd "<<endl; pte.PrintPoint(); cout<<" The Length of Line: "<<Length()<<endl;}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;}
运行结果:
0 0
- 第十一周项目3-点类派生直线类
- 第十一周 项目3--点类派生直线类
- 第十一周 项目 3 点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周 项目 3 点类派生直线类 .
- 第十一周 项目 3 点类派生直线类
- 第十一周-项目3-点类派生直线类
- 第十一周项目3点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周 项目3-点类派生直线类
- 第十一周【项目3 - 点类派生直线类】
- 第十一周项目3--点类派生直线类
- 第十一周项目3:点类派生直线类
- 第十一周 项目3-点类派生直线类
- 第十一周项目3 - 点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周 项目3 - 点类派生直线类
- 理解c语言的sizeof
- 二分查找(Binary Search)需要注意的问题,以及在数据库内核中的实现
- 二分查找的一个题---找出排序数组中绝对值最小的数
- 数据源与连接池的关系
- HDU2094---产生冠军
- 第十一周项目3 - 点类派生直线类
- LeetCode Search for a Range
- 吉他和弦小记
- UIImage 图像-IOS开发
- c/c++ 笔记本
- HttpClient.execute() 阻塞问题
- 【Android】SlidingMenu属性详解
- 针对类的向量增加及获得元素示例
- MPMoviePlayerController 电影播放器—IOS开发