/*
* Copyright (c) 2014, 烟台大学计算机学院
* All rights reserved.
* 文件名称:test.cpp
* 作 者:李晓凯
* 完成日期:2015年 4 月 12 日
* 版 本 号: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 getX();
double getY();
double distance1(CPoint p); //成员函数求两点间的距离
friend double distance2(CPoint &,CPoint &); //友元函数求两点间的距离
};
double distance3(CPoint ,CPoint );
void CPoint::input()
{
char c;
while(1)
{
cin>>x>>c>>y;
if(c!=',')
{
cout<<"格式错误,请重新输入!"<<endl;
continue;
}
else
break;
}
}
double CPoint::getX()
{
return x;
}
double CPoint::getY()
{
return y;
}
double CPoint::distance1(CPoint p)
{
return sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));
}
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 p1,p2(4,5);
cout<<"请输入两个点p1的坐标(格式为:m,n):"<<endl;
p1.input();
cout<<"两点间的距离为:"<<p1.distance1(p2)<<endl;
cout<<"两点间的距离为:"<<distance2(p1,p2)<<endl;
cout<<"两点间的距离为:"<<distance3(p1,p2)<<endl;
}
学习总结:友元函数能够直接访问私有数据成员,很容易编写,再一个是一般函数提取私有数据成员的数值,刚开始忘记怎么做了,后来看了看以前写的就豁然开朗了!!!