第十周 任务一

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* 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;
}


上机感言:继承和派生很好,省去了许多麻烦,缩短了代码的长度
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值