/* Copyright (c) 2012, 烟台大学计算机学院
* All rights reserved.
* 文件名称:text.cpp
* 作 者: 胡颖
*完成日期:2013年5月11日
* 版 本 号:v1.0
*
* 输入描述:无
* 问题描述:略
* 程序输出:输出直线长度及其中点,端点坐标
* 问题分析:定义点类,并以点类为基类,派生出直线类,从基类中继承的点的信息表示直线的中点。
* 算法设计:略
*/
#include<iostream>
#include<Cmath>
using namespace std;
class Point //定义坐标点类
{
public:
Point():x(0),y(0){};//点坐标初始化为0
Point(double x0,double y0):x(x0),y(y0){};
double getX()
{
return x;
}
double getY()
{
return y;
}
void PrintPoint(); //输出点的信息
private:
double x,y; //点的横坐标和纵坐标
};
class Line: public Point //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点
{
public:
Line(Point pt1, Point pt2); //构造函数,用初始化直线的两个端点及由基类数据成员描述的中点
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=(pte.getX()-pts.getX());
double dy=(pte.getY()-pts.getY());
return sqrt(dx*dx+dy*dy);
}
void Point::PrintPoint()
{
cout<<"point:("<<x<<","<<y<<")"<<endl;
}
void Line::PrintLine()
{
cout<<"The frist point is:";
pts.PrintPoint();
cout<<"The second point is:";
pte.PrintPoint();
cout<<"The length of line is:"<<length()<<endl;;
}
int main()
{
Point ps(-2,5),pe(7,9);
Line l(ps,pe);
//下面输出直线l的端点、长度和、中点的信息
cout<<"直线l的信息:"<<endl;
l.PrintLine();
cout<<"直线中点的信息:"<<endl;
l.PrintPoint();
return 0;
}
运行结果: