第十周任务一 线类继承点类

来源:互联网 发布:2ne1为什么解散 知乎 编辑:程序博客网 时间:2024/04/28 16:48
/* (程序头部注释开始)* 程序的版权和版本声明部分* Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved.* 文件名称:  point to line                            * 作    者:   姜雅明                              * 完成日期:   2012      年   04    月    24    日* 版 本 号:          * 对任务及求解方法的描述部分* 输入描述: 两个点的坐标* 问题描述: 根据两个点,计算直线的中点和长度* 程序输出: 直线的中点和长度* 程序头部的注释结束*/#include<iostream>#include<Cmath>using namespace std;class Point //定义坐标点类{public:double x, y;   //点的横坐标和纵坐标Point(){x = 0;y = 0;}Point(double x0,double y0) {x = x0; y = y0;} void PrintP(){cout << "Point:(" << x << "," << y << ")" << endl;}};  class Line: public Point   //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点{private:class Point pt1,pt2;   //直线的两个端点public:Line(Point pts, Point pte);  //构造函数double Dx(){return pt2.x-pt1.x;}double Dy(){return pt2.y-pt1.y;}double Length();//计算直线的长度void PrintL();  //输出直线的两个端点和直线长度};//构造函数,分别用参数初始化对应的端点及由基类属性描述的中点Line::Line(Point pts, Point pte):Point ((pte.x + pts.x) / 2, (pte.y + pts.y) / 2), pt1(pte), pt2(pts){};double Line::Length(){return sqrt(Dx() * Dx() + Dy() * Dy());};//计算直线的长度void Line::PrintL(){cout << " 1st ";pt1.PrintP();cout << " 2nd ";pt2.PrintP();cout << " The middle point of Line: ";PrintP();cout << " The Length of Line: " << Length() << endl;}int main(){Point ps(-2,5),pe(7,9);Line l(ps,pe);l.PrintL();//输出直线l的信息pe.PrintP();  ps.PrintP();//输出直线l中点的信息system("pause");return 0;}输出结果:/* 1st Point:(7,9)* 2nd Point:(-2,5)* The middle point of Line: Point:(2.5,7)* The Length of Line: 9.84886*Point:(7,9)*Point:(-2,5)*请按任意键继续. . .*/