01./* (程序头部注释开始)
02.* 程序的版权和版本声明部分
03.* Copyright (c) 2011, 烟台大学计算机学院学生
04.* All rights reserved.
05.* 文件名称:
06.* 作 者: 王明星
07.* 完成日期: 2012 年 4 月 16 日
08.* 版 本 号:
09.
10.* 对任务及求解方法的描述部分
11.* 输入描述:
12.* 问题描述:实现分数类中的<<和>>运算符重载,实现分数的输入和输出
13.* 程序头部的注释结束
14.*/
#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((pte.x+pts.x)/2,(pte.y+pts.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 L(ps,pe);
L.printL();//输出直线l的信息
L.printp();//输出直线l中点的信息
system("pause");
return 0;
}
上机感言:派生类也是一个类,不过是在基类的基础上扩充得到的类罢了!