求两点间距离

上机内容:利用类的成员函数,友元函数,普通函数,分别求出两点间的距离

上机目的:知道成员函数,普通函数,友元函数之间的区别

我的程序:

/*  
* 程序的版权和版本声明部分:   
* 作    者:烟台大学计算机学院学生:段元晋
* 完成日期:2013年4月11号
* 版 本 号:vc++6.0
* 对任务及求解方法的描述部分: 
* 输入描述:无
* 问题描述:求两点间的距离
* 程序输出:略
* 问题分析:略 
* 算法设计:略  
*/
#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 getX(){return x;}
	double getY(){return y;}
	double juli1(CPoint &);//求距离的成员函数声明
	friend double juli2(CPoint &c1,CPoint &c2);//求距离的友元函数声明
};
double juli3(CPoint &,CPoint &);//求距离的普通函数声明
double CPoint::juli1(CPoint &c)//定义成员函数
{
	cout<<"点"<<"("<<x<<","<<y<<")";
	cout<<"和点"<<"("<<c.x<<","<<c.y<<")";
	cout<<"间的距离:";
	double x1=x-c.x;
	double y1=y-c.y;
    return (sqrt(x1*x1+y1*y1));
}

double juli2(CPoint &c1,CPoint &c2)//定义友元函数
{
	cout<<"点"<<"("<<c1.x<<","<<c1.y<<")";
	cout<<"和点"<<"("<<c2.x<<","<<c2.y<<")";
	cout<<"间的距离:";
	double x1=c1.x-c2.x;
	double y1=c1.y-c2.y;
	return (sqrt(x1*x1+y1*y1));
}
double juli3(CPoint &c1,CPoint &c2)
{
	cout<<"点"<<"("<<c1.getX()<<","<<c1.getY()<<")";
	cout<<"和点"<<"("<<c2.getX()<<","<<c2.getY()<<")";
	cout<<"间的距离:";
	double x1=c1.getX()-c2.getX();
	double y1=c1.getY()-c2.getY();
	return (sqrt(x1*x1+y1*y1));
}

int main()
{
	CPoint c1(0,0),c2(3,4);
	cout<<c1.juli1(c2)<<endl;
    cout<<juli2(c1,c2)<<endl;
	cout<<juli3(c1,c2)<<endl;
	return 0;
}
运行结果:


评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值