/*
*程序的版权和版本声明部分:
*Copyright(c)2013,烟台大学计算机学院学生
*All rights reserved.
*文件名称:
*作者:席翱翔
*完成日期:2014年4月15日
*版本号:v0.1
*对任务及求解方法的描述部分:
*输入描述:无
*问题描述:
*程序输入:
*程序输出:
*问题分析:
*算法设计:
*我的程序:
*/
#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 &); //distance1是成员函数
friend double distance2(CPoint &,CPoint &);//distance2是友元函数
double getX(){return x;}
double getY(){return y;}
};
double CPoint::distance1(CPoint &p)//是成员函数
{
double dx=(x-p.x),dy=(y-p.y);
return sqrt(dx*dx+dy*dy);
}
double distance2(CPoint &p1,CPoint &p2)//是友元函数
{
double dx=(p1.x-p2.x),dy=(p1.y-p2.y);
return sqrt(dx*dx+dy*dy);
}
double distance3(CPoint &p1,CPoint &p2)//是一般函数
{
double dx=(p1.getX()-p2.getX()),dy=(p1.getY()-p2.getY());
return sqrt(dx*dx+dy*dy);
}
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;
}
结果: