1.问题与代码
/*
* 文件名称: 友元函数
* 作 者:王泽文
* 完成日期:2016 年 4 月 8日
* 版 本 号: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(CPoint &p);
friend double Distance2(CPoint &p1,CPoint &p2);
double getx(){return x;}
double gety(){return y;}
};
double CPoint::Distance1(CPoint &p2)
{
double x1=p2.x-x;
double y1=p2.y-y;
double d=sqrt(x1*x1+y1*y1);
return d;
}
double Distance2(CPoint &p1,CPoint &p2)
{
double x1=p1.x-p2.x;
double y1=p1.y-p2.y;
double d=sqrt(x1*x1+y1*y1);
return d;
}
double Distance3(CPoint &p1,CPoint &p2)
{
double x1=p1.getx()-p2.getx();
double y1=p1.gety()-p2.gety();
double d=sqrt(x1*x1+y1*y1);
return d;
}
int main()
{
CPoint p1(6,4),p2(2,9);
cout<<"两点之间的距离:"<<p1.Distance1(p2)<<endl;
cout<<"两点之间的距离:"<<Distance2(p1,p2)<<endl;
cout<<"两点之间的距离:"<<Distance3(p1,p2)<<endl;
return 0;
}
2.运行结果
3.心得体会:友元函数学习
4知识点总结:友元函数使用