第十周 任务一
/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 流运算符重载运算符(解方程)
* 作 者: 薛广晨
* 完成日期: 2012 年 4 月 19 日
* 版 本 号: x1.0
* 对任务及求解方法的描述部分
* 输入描述: 继承和派生
* 问题描述: 计算直线的长度
* 程序输出: ......
* 程序头部的注释结束
*/
//【任务1】在下面一段类的定义中,需要填充的函数由注释内容给出了功能。
#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 << ")";}
};
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 middle(); //计算
double Length(); //计算直线的长度
void PrintL(); //输出直线的两个端点和直线长度
};
//构造函数,分别用参数初始化对应的端点及由基类属性描述的中点
Line :: Line(Point pts, Point pte) : Point((pts.x + pte.x) / 2, (pts.y + pte.y) / 2)
{
pt1 = pts;
pt2 = pte;
}
double Line :: Length(){return sqrt(Dx() * Dx() + Dy() * Dy());}//计算直线的长度
void Line :: PrintL()
{
cout << " 1st ";
pt1.PrintP();
cout << "\n 2nd ";
pt2.PrintP();
cout << "\n The middle point of Line: ";
PrintP();
cout << "\n The Length of Line: " << Length() << endl;
}
int main()
{
Point ps(-2, 5), pe(7, 9);
Line I (ps, pe);
I.PrintL();//输出直线l的信息
I.PrintP();//输出直线l中点的信息
cout << endl;
system("pause");
return 0;
}
上机感言:继承和派生很好,省去了许多麻烦,缩短了代码的长度
还没有评论,来说两句吧...