/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:求两点间距离
* 作 者: 刘向一
* 完成日期: 2012 年 4 月3 日
* 版 本 号: V1.0
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束
*/
#include<iostream>
#include<Cmath>
using namespace std;
class CPoint
{
private:
double x; // 横坐标
double y; // 纵坐标
public:
CPoint(double xx=0, double yy=0):x(xx),y(yy){}
double distance1(const CPoint &p);
friend double distance2(const CPoint &p1,const CPoint &p2);
double getx() const {return x;}
double gety() const {return y;}
};
double distance3(const CPoint &p1,const CPoint &p2);
double CPoint::distance1(const CPoint &p)
{
double dx=this->x-p.x;
double dy=this->y-p.y;
return sqrt(dx*dx+dy*dy);
}
double distance2(const CPoint &p1,const CPoint &p2)
{
double dx=p1.x-p2.x;
double dy=p1.y-p2.y;
return sqrt(dx*dx+dy*dy);
}
double distance3(const CPoint &p1,const CPoint &p2)
{
double dx=p1.getx()-p2.getx();
double dy=p1.gety()-p2.gety();
return sqrt(dx*dx+dy*dy);
}
int main()
{
CPoint p1(2,4);
CPoint p2(3,7);
cout<<p2.distance1(p1)<<endl;
cout<<distance2(p1,p2)<<endl;
cout<<distance3(p1,p2)<<endl;
system("pause");
return 0;
}