11.3 点类派生直线类
来源:互联网 发布:ubuntu mount ntfs 编辑:程序博客网 时间:2024/06/05 06:26
/** Copyright (c) 2014, 烟台大学计算机学院* All rights reserved.* 作 者:王颖* 完成日期:2014 年 5 月 7 日* 版 本 号:v1.0* 输入描述: 无* 问题描述: 点类派生直线类* 程序输出:略* 问题分析:略* 算法设计:略*/#include<iostream>#include<Cmath>using namespace std;class Point //定义坐标点类{public: Point():x(0),y(0) {}; Point(double x0, double y0):x(x0), y(y0) {}; void PrintPoint(); //输出点的信息 int getx() { return x; } int gety() { return y; }protected: double x,y; //点的横坐标和纵坐标};void Point::PrintPoint(){ cout<<"中点为Point: ("<<x<<","<<y<<")"; //输出点}class Line: public Point //利用坐标点类定义直线类, 其基类的数据成员表示直线的中点{public: Line(Point pts, Point pte); //构造函数,用初始化直线的两个端点及由基类数据成员描述的中点 double Length(); //计算并返回直线的长度 void PrintLine(); //输出直线的两个端点和直线长度private: class Point pts,pte; //直线的两个端点,从Point类继承的数据成员表示直线的中点};Line::Line(Point pts, Point pte):pts(pts),pte(pte){}double Line::Length(){ double m,n,s; x=(pts.getx()+pte.getx())/2; y=(pts.gety()+pte.gety())/2; m=(pts.getx()-pte.getx())*(pts.getx()-pte.getx()); n=(pts.gety()-pte.gety())*(pts.gety()-pte.gety()); s=sqrt(m+n); return s;}void Line::PrintLine(){ cout<<"直线端点为:"<<"("<<pts.getx()<<","<<pts.gety()<<")"<<endl; cout<<"("<<pte.getx()<<","<<pte.gety()<<")"<<endl; cout<<"直线长度为:"<<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;}
0 0
- 点派生类直线
- 点派生直线类
- 11.3 点类派生直线类
- 11.3-点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生直线类
- 点类派生出直线类,直线类派生出圆类
- iOS开发之归档
- 浅谈数据库的分割技术
- quick_cocos2dx 初体验 (一)
- Failed to connect to 127.0.0.1:27017
- 计算UDP校验和遇到的弱智问题。不知道对初学者有没有用
- 11.3 点类派生直线类
- VirtualBox安装Ubuntu图文介绍
- java学习笔记之入门
- 微软智能手表专利曝光 主打健身追踪
- 精益敏捷开发下的软件架构设计
- Cocos2dx 小技巧(十三)聊聊坐标系
- SharedPreferences
- 终于赶在软件测试部前头解决Access数据库压缩的问题
- leetcode第一刷_Distinct Subsequences