(2)模仿上面的示例,完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计main()函数完成测试。
提示:此项目和例子的区别在于“距离是一个点和另外一个点的距离”,不同版本在参数上有体现。三个版本建议分开测试,也可以如示例,放在一个程序中完成。
下面是点类的部分代码。
class CPoint
{
private:
double x; // 横坐标
double y; // 纵坐标
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy){}
……//请继续写需要的代码
};
解决代码:
#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){}
void distance1(CPoint &);
friend void distance2 (CPoint &,CPoint &);
int getx(){return x;}
int gety(){return y;}
};
void CPoint::distance1(CPoint &t)
{
cout<<sqrt((this->x-t.x)*(this->x-t.x)+(this->y-t.y)*(this->y-t.y))<<endl;
}
void distance2 (CPoint &t1,CPoint &t2)
{
cout<<sqrt((t1.x-t2.x)*(t1.x-t2.x)+(t1.y-t2.y)*(t1.y-t2.y))<<endl;
}
void distance3 (CPoint &t1,CPoint &t2)
{
cout<<sqrt((t1.getx()-t2.getx())*(t1.getx()-t2.getx())+(t1.gety()-t2.gety())*(t1.gety()-t2.gety()))<<endl;
}
int main()
{
CPoint p1(5,8),p2(8,9);
p1.distance1(p2);
distance2(p1,p2);
distance3(p1,p2);
return 0;
}
学习心得:三种函数运用得更加熟练了。