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

本文介绍了一个使用C++实现的程序,该程序根据输入的两个点的坐标计算出这两点形成的直线的中点坐标和直线长度。通过定义坐标点类和直线类,实现了对几何计算的封装。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

/* (程序头部注释开始)
* 程序的版权和版本声明部分
* 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)
*请按任意键继续. . .
*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值