第十一周 项目3--点类派生到直线类(Point类中的数据成员为protected型)

来源:互联网 发布:vb中文本框自动换行 编辑:程序博客网 时间:2024/06/05 18:08
/**程序的版权和版本声明部分:*Copyright(c)2013,烟台大学计算机学院学生*All rights reserved.*文件名称:*作者:尚振伟*完成日期:2014年5月6日*版本号:v0.1*对任务及求解方法的描述部分:*输入描述:无*问题描述:定义点类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) {};    void PrintPoint(); //输出点的信息    double get_x()    {        return x;    }    double get_y()    {        return y;    }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类继承的数据成员表示直线的中点};Line::Line(Point pts, Point pte):Point((pts.get_x()+pte.get_x())/2,(pts.get_y()+pte.get_y())/2){    (*this).pts=pts;    (*this).pte=pte;}double Line::Length(){    double l;    l=sqrt(pow((pts.get_x()-pte.get_x()),2)+pow((pts.get_y()-pte.get_y()),2));    return l;}void Line::PrintLine(){    pts.PrintPoint();    pte.PrintPoint();    cout<<"The distance of the two Points:";    cout<<Length()<<endl;}int main(){    Point ps(-16,9),pe(-6,3);    Line l(ps,pe);    cout<<"About the Line: "<<endl;    l.PrintLine();  //输出直线l的信息:两端点及长度    cout<<"The middle point of Line is: ";    l.PrintPoint(); //输出直线l中点的信息    return 0;}


结果展示:

心得体会:比public型的稍微麻烦了那么一点点----把protected型的想x,y取出来,变成public型的。

0 0