/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2012, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称: 求点类中距离
* 作 者: 刘镇
* 完成日期: 2012 年 3 月 31 日
* 版 本 号: 1.045
* 对任务及求解方法的描述部分
* 输入描述:两个坐标点
* 问题描述: 如何用友元访问,比较一般函数之间的区别
* 程序输出: 点间距
* 程序头部的注释结束
*/
#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) const; // 两点之间的距离(一点是当前点,另一点为参数p)
friend double Distance2(CPoint &,CPoint &); //友元函数实现求两点距离
void input(); //以x,y 形式输入坐标点
void output(); //以(x,y) 形式输出坐标点
double getx(){return x;} //用于得到x
double gety(){return y;} //用于得到y
};
double Distance3(CPoint &,CPoint &);
double CPoint::Distance1(CPoint p) const
{
return sqrt((p.x - x) * (p.x - x) + (p.y - y) * (p.y - y));
}
void CPoint::input()
{
char c;
cout << "请输入点坐标:(格式:x,y)" << endl;
do
{
cin >> x >> c >> y;
if(c == ',')
{
break;
}
cout << "格式不正确,请重新输入:" << endl;
}while(1);
}
void CPoint::output()
{
cout << "点坐标(" << x << "," << y << ")" << endl;
}
double Distance2(CPoint &p1,CPoint &p2)
{
return sqrt((p1.x - p2.x) * (p1.x - p2.x) + (p1.y - p2.y) * (p1.y - p2.y));
}
double Distance3(CPoint &p1,CPoint &p2)
{
return sqrt((p1.getx() - p2.getx()) * (p1.getx() - p2.getx()) + (p1.gety() - p2.gety()) * (p1.gety() - p2.gety()));
}
int main()
{
CPoint c1, c2;
c1.input();
c2.input();
c1.output();
c2.output();
cout << "两点间的距离是:" << c1.Distance1(c2) << endl;
cout << "两点间的距离是:" << Distance2(c1, c2) << endl;
cout << "两点间的距离是:" << Distance3(c1, c2) << endl;
system("pause");
}
运行结果:

感言:
有元就是牛,有了通行证,就可以用“私有物品”了,但毕竟不是自己家的,还是要点名对象是谁;一般函数就要惨点了,就只能靠大众化的接口实现功能了。
本文介绍了一个使用C++实现的点类,该类能够通过不同方法计算两点之间的距离,包括成员函数、友元函数和通用函数的方式,并对比了它们的区别。
431





