问题及代码:
/*
* Copyright (c) 2015, 烟台大学计算机学院
* All rights reserved.
* 文件名称:read.cpp
* 作 者:李楠
* 完成日期:2015年4月9日
* 版 本 号:v1.0
*
* 问题描述:(2)模仿上面的示例,完成求点类中距离的任务。你需要实现求距离函数的三种版本:分别利用成员函数、友元函数和一般函数求两点间距离的函数,并设计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 Distance1(CPoint p) const;//两点之间的距离(一点是当前点——想到this了吗?,另一点为p)
friend void Distance2(CPoint &t,CPoint &p);
void Distance3(CPoint &t,CPoint &p);
double outputx();
double outputy();
};
void CPoint::Distance1(CPoint p) const //成员函数display1的实现,dispaly1前加Time::
{
double l;
l=sqrt((this->x-p.x)*(this->x-p.x)+(this->y-p.y)*(this->y-p.y));
cout<<l<<endl;
}
void Distance2(CPoint &t,CPoint &p) //友元函数dispaly2的实现,不加Time::,友元并不是类的成员
{
double l;
l=sqrt((p.x-t.x)*(p.x-t.x)+(p.y-t.y)*(p.y-t.y));
cout<<l<<endl;
}
void Distance3(CPoint &t,CPoint &p) //display3是一般函数,dispaly3前不加Time::
{
double l;
l=sqrt((p.outputx()-t.outputx())*(p.outputx()-t.outputx())+(p.outputy()-t.outputy())*(p.outputy()-t.outputy()));
cout<<l<<endl;
}
double CPoint::outputx()
{
return x;
}
double CPoint::outputy()
{
return y;
}
int main()
{
CPoint P1(3.0,4.0);
CPoint P2;
P1.Distance1(P2); //成员函数这样调用:对象名.函数名()
Distance2(P1,P2); //友员函数的调用和一般函数无异(但实现中可以不同)
Distance3(P1,P2); //一般函数的调用
return 0;
}
运行结果:
知识点总结:
根据所给的例子,写出友元函数,注意函数的参数和例子不太一样~
学习心得:
懂得举一反三,并且能从中领悟到道理~