/* (程序头部注释开始)
* 程序的版权和版本声明部分
* Copyright (c) 2011, 烟台大学计算机学院学生
* All rights reserved.
* 文件名称:理解成员函数、友元函数和一般函数的区别 并会熟练使用它们
* 作 者: 雷恒鑫
* 完成日期: 2012 年 03 月 29 日
* 版 本 号: V1.0
* 对任务及求解方法的描述部分
* 输入描述:
* 问题描述:
* 程序输出:
* 程序头部的注释结束
*/
#include <iostream>
#include <cmath>
using namespace std;//你需要完成的任务是,利用成员函数、友元函数和一般函数,实现三个版本的求两点间距离的函数,并设计main()函数完成测试。此任务和上例的区别在于"距离是一个点和另外一个点的距离",参数个数上有体现。下面是点类的部分代码。
class CPoint
{
private:
double x; // 横坐标
double y; // 纵坐标
public:
CPoint(double xx=0,double yy=0):x(xx),y(yy){}
double Distance1(CPoint p) ; // 两点之间的距离(一点是当前点,另一点为参数p)
friend double Distance3(CPoint &t1,CPoint &t2) ; // 两点之间的距离
void input(); //以x,y 形式输入坐标点
double getx();
double gety();
};
//返回坐标点
double CPoint::getx()
{
return x;
}
double CPoint::gety()
{
return y;
}
// 输入坐标点
void CPoint::input()
{
char ch;
cout<<"请输入坐标点(格式x,y ):";
while(1)
{
cin>>x>>ch>>y;
if (ch==',') break;
cout<<"输入的数据格式不符合规范,请重新输入\n";
}
}
// 求点到原点的距离
//成员函数定义
double CPoint::Distance1(CPoint p)
{
double d;
d=sqrt((p.x-x)*(p.x-x)+(p.y-y)*(p.y-y));//将(p.x-x)更改为(p.x-this->x)可以更便于理解,d是当前点*this和参数给出的点p间的距离
return d;
}
//一般函数定义
double Distance2(CPoint &t1,CPoint &t2)
{
double m,n,p,q,d;
m=t1.getx();
n=t1.gety();
p=t2.getx();
q=t2.gety();
d=sqrt((m-p)*(m-p)+(n-q)*(n-q));
return d;
}
// 友元函数定义
double Distance3(CPoint &t1,CPoint &t2)
{
double m,n,p,q,d;
m=t1.x;
n=t1.y;
p=t2.x;
q=t2.y;
d=sqrt((m-p)*(m-p)+(n-q)*(n-q));
return d;
}
void main( )
{
double distance;
CPoint p1,p2;
cout<<"第1个点p1,";
p1.input();
cout<<"第2个点p2,";
p2.input();
distance=p1.Distance1(p2);
cout<<"用成员函数调用求得的两点的距离为:"<<distance<<endl;
distance=Distance2(p1,p2);
cout<<"用一般函数调用求得的两点的距离为:"<<distance<<endl;
distance=Distance3(p1,p2);
cout<<"用友元函数调用求得的两点的距离为:"<<distance<<endl;
system("pause");
}
运行结果:
经验积累:
1.论亲缘关系的远近,成员函数》友元函数》一般函数