第六周项目四:分别利用成员函数、友元函数和一般函数求距离



(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;
}


学习心得:三种函数运用得更加熟练了。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值