/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:刘佳琦
* 完成日期:2015年 4 月 10 日
* 版 本 号:v1.0
*
* 问题描述:模仿上面的示例,完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计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) {}
void input();
double distance1(CPoint &);
friend double distance2(CPoint &, CPoint &) ;
double getX()
{
return x;
}
double getY()
{
return y;
}
};
double distance3(CPoint &,CPoint &) ;
void CPoint::input()
{
cout<<"请输入坐标(x,y)形式:"<<endl;
char c;
cin>>x>>c>>y;
}
double CPoint::distance1(CPoint &p)
{
return sqrt((x-p.x)*(x-p.x)+(y-p.y)*(y-p.y));
}
double distance2(CPoint &p1,CPoint &p2)
{
return sqrt((p2.x-p1.x)*(p2.x-p1.x)+(p2.y-p1.y)*(p2.y-p1.y));
}
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, p2;
p1.input();
p2.input();
cout<<p1.distance1(p2)<<endl;
cout<<distance2(p1,p2)<<endl;
cout<<distance3(p1,p2)<<endl;
return 0;
}
运行结果:
学习心得:
通过上一个例子还有书上所学内容,很容易的就写出来这个程序,其中友元函数和一般函数在形式上很是相像,但其实在实现上不一样。友元函数可以直接用类的成员,但是一般函数必须通过调用函数才能访问类的私有成员。