第十一周项目三点类派生直线类(有疑问)
来源:互联网 发布:中科院对学生调查数据 编辑:程序博客网 时间:2024/05/22 17:11
/** 程序的版权和版本声明部分* Copyright (c)2014, 烟台大学计算机学院学生* All rightsreserved.* 文件名称:student .cpp* 作者:纪丽娜* 完成日期:2014年5月7日* 版本号: v1.0* 问题描述:定义点类Point,并以点类为基类,派生出直线类Line,从基类中继承的点的信息表示直线的中点。*/#include<iostream>#include<Cmath>using namespace std;class Point //定义坐标点类{public: Point():x(0),y(0) {} Point(double x0, double y0):x(x0),y(y0){} double getX() { return x; } double getY() { return y; } void PrintPoint(); //输出点的信息protected: double x,y; //点的横坐标和纵坐标};void Point::PrintPoint(){ cout<<"Point: ("<<x<<","<<y<<")"<<endl; //输出点}class Line: public Point //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点{public: Line(Point pts, Point pte); //构造函数,用初始化直线的两个端点及由基类数据成员描述的中点 double Length(); //计算并返回直线的长度 void PrintLine(); //输出直线的两个端点和直线长度private: Point pts,pte; //直线的两个端点,从Point类继承的数据成员表示直线的中点};//构造函数,分别用初始化直线的两个端点及由基类数据成员(属性)描述的中点Line::Line(Point pt1, Point pt2):Point((pt1.getX()+pt2.getX())/2,(pt1.getY()+pt2.getY())/2)//基类的点{ pts=pt1; pte=pt2; //派生类的点}double Line::Length() //计算并返回直线的长度{ double dx=pts.getX()-pte.getX(); double dy=pts.getY()-pte.getY(); return sqrt(dx*dx+dy*dy);}void Line::PrintLine(){ cout<<" 1st "<<endl; pts.PrintPoint(); cout<<" 2nd "<<endl; pte.PrintPoint(); cout<<" The Length of Line: "<<Length()<<endl;}int main(){ Point ps(-2,5),pe(7,9); //点 Line l(ps,pe); //线! cout<<"About the Line: "<<endl; l.PrintLine(); //输出直线l的信息:两端点及长度 cout<<"The middle point of Line is: "; l.PrintPoint(); //输出直线l中点的信息 return 0;}
心得:为什么不能直接这样写
Line::Line(Point pt1, Point pt2):Point((pt1.x+pt2.x)/2,(pt1.y+pt2.y)/2)//基类的点{ pts=pt1; pte=pt2; //派生类的点}double Line::Length() //计算并返回直线的长度{ double dx=pts.x()-pte.x; double dy=pts.y-pte.y; return sqrt(dx*dx+dy*dy);}
会提示x,y是被保护的,可是定义保护的基类的派生类不是能用吗???
private 的才不能用啊。。。。
0 0
- 第十一周项目三点类派生直线类(有疑问)
- 第十一周项目三点类派生直线类
- 第十一周项目三点类派生直线类
- 第十一周上机项目三点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周 项目3--点类派生直线类
- 第十一周 项目 3 点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周 项目 3 点类派生直线类 .
- 第十一周 项目 3 点类派生直线类
- 第十一周-项目3-点类派生直线类
- 第十一周项目三 点类派生直线类
- 第十一周项目五 点类派生直线类
- 第十一周 项目三:点类派生直线类
- 第十一周项目3点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周项目3-点类派生直线类
- 第十一周上机项目4点类派生直线类
- 单身女青年的购房之路
- Uva 1121Subsequence
- uva 146 ID Codes (下一个排列)
- OCP 1Z0 051 3
- 挑战面试编程:计算整数二进制位中1的个数
- 第十一周项目三点类派生直线类(有疑问)
- OpenGL ES From the Ground Up, Part 1 Addendum: Alphabet Soup
- JavaScript中this关键字使用方法详解
- XML 简介 (from W3C School)
- OpenGL ES From the Ground Up, Part 1: Basic Concepts
- mysql “group by ”与"order by"的研究--分类中最新的内容
- struts2的工作原理
- SIFT算法学习
- linux中对EINTR错误的处理