你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。
提示:此项目和例子的区别在于“距离是一个点和另外一个点的距离”,不同版本在参数上有体现。三个版本建议分开测试,也可以如示例,放在一个程序中完成。
#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(CPoint &a);
friend double distance2(CPoint &a, CPoint &b);
double getx()
{
return x;
}
double gety()
{
return y;
}
};
double distance3(CPoint &a, CPoint &b);
int main()
{
CPoint p1(10,13), p2(-5,6);
cout<<"1. "<<p1.distance1(p2)<<endl;
cout<<"2. "<<distance2(p1,p2)<<endl;
cout<<"3. "<<distance3(p1,p2)<<endl;
return 0;
}
double CPoint::distance1(CPoint &a)
{
return sqrt((this->x - a.x) * (this->x - a.x) + (this->y - a.y) * (this->y - a.y));
}
double distance2(CPoint &a, CPoint &b)
{
return sqrt((a.x - b.x) * (a.x - b.x) + (a.y - b.y) * (a.y - b.y));
}
double distance3(CPoint &a, CPoint &b)
{
return sqrt((a.getx() - b.getx()) * (a.getx() - b.getx()) + (a.gety() - b.gety()) * (a.gety() - b.gety()));
}