第十周任务一:求两点之间的直线长度
2012-04-23 18:32
204 查看
* 程序头部注释开始 * 程序的版权和版本声明部分 * Copyright (c) 2011, 烟台大学计算机学院学生 * All rights reserved. * 文件名称: * 作 者: 田庆 * 完成日期: 2012 年 4 月23 日 * 版 本 号: * 对任务及求解方法的描述部分 * 输入描述: *问题描述:给出两点求其中点及两点之间的距离 * 算法说明: * 程序头部的注释结束(此处也删除了斜杠) #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((pts.x+pte.x)/2,(pts.y+pte.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; }
小结:开始运行时提示能运行,但是有强制类型转换double转向int型,后来又把原来定义的int型都转换为了double型,没有提示还是运行起来感觉舒服些。
相关文章推荐
- Mapxtreme2005 两点之间画直线
- 两点之间最短的距离并不一定是直线(改变一生财运的五句话)
- 关于如何求无向无环图中所有两点之间的长度和
- 第六周实验指导--任务3--设计平面坐标点类,计算两点之间距离
- Python-类03(求两点之间直线距离)
- 两点之间插值成一条直线
- 计算两点之间连线的一半长度
- Unity计算两点之间的距离或者向量的长度常用方法
- swing 两点之间直线上的任意距离点的坐标
- 已知A,B两点及C点(不在直线AB上)坐标,求在直线AB上距离A点距离为线段AC长度的点D坐标
- 两点之间走直线真的最近吗?
- 两点之间最快的路线竟然不是直线
- C++第六周任务三设计平面坐标点类,计算两点之间距离、到原点距离、关于坐标轴和原点的对称点等
- 第七周实验报告(任务二)【求两点之间的距离】
- Unity 通过LineRenderer绘制两点之间的直线
- gMap两点之间画路线和直线的方法
- C++ 第八周任务-求两点之间距离
- 两点之间最短的距离并不一定是直线
- 最短路径问题平面上有n个点(n<=100),每个点的坐标均在-10000~10000之间。其中的一些点之间有连线。若有连线,则表示可从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。
- 第十周实验报告任务1 由坐标点类派生出直线类