第十周实验报告1(派生类)

程序头部注释开始
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:      (派生类)     
* 作    者:     王智凯                       
* 完成日期:  2012年    4  月  22  日
* 版 本 号:  凯子

 

#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 Length();//计算直线的长度
	void PrintL();  //输出直线的两个端点和直线长度
};
//构造函数,分别用参数初始化对应的端点及由基类属性描述的中点
Line::Line(Point pts, Point pte):Point(x,y)
{
	pt1 = pts;
	pt2 = pte;
	x = (pte.x-pts.x)/2;
	y = (pte.y-pts.y)/2;

}
double Line::Length(){return sqrt(Dy()*Dy()+Dx()*Dx());}//计算直线的长度
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 l(ps,pe);
	l.PrintL();//输出直线l的信息
	l.PrintP();//输出直线l中点的信息
	system("pause");
	return 0;
}


上机感言:看课本,写程序。。。。。。。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值