采用成员函数和友元函数计算给定两个坐标点之间的距离

该代码示例定义了一个Location类,用于表示直角坐标系中的点。通过构造函数初始化坐标,并提供了成员函数获取坐标值。同时,实现了计算两点间距离的成员函数distance1和友元函数distance2。在主函数中,创建了位于第三象限的点A和第二象限的点B,并分别调用两个函数计算它们之间的距离。
摘要由CSDN通过智能技术生成

设计一个用来表示直角坐标系的Location类,在主程序中创建类Location的两个对象A和B,要求A的坐标在第3象限,B的坐标点在第2象限,分别采用成员函数和友元函数计算给定两个坐标点之间的距离

#include<iostream>
#include<cmath>
using namespace std;

class Location					//声明类Location
{
public:
	Location(double a,double b);	//构造函数	
	double Getx(){return x;}				//成员函数,取x坐标的值
	double Gety(){return y;}				//成员函数,取y坐标的值
	double distance1(Location&);//成员函数,求两坐标点之间的距离
	friend double distance2(Location &a, Location &b);//友元函数,求两坐标点之间的距离
private:
	double x,y;
};


	Location::Location(double a,double b):	x(a),y(b){
	
	}
double distance2(Location &a, Location &b){
	double dis;
	dis = pow(pow(a.x-b.x,2)+pow(a.y-b.y,2),0.5);
	cout << dis << endl; 
}

int main(void)
{
	double a,b,c,d;
	cin >> a >> b >> c >> d;
	Location location1(a,b);
	Location location2(c,d);
	location1.Getx();
	location1.Gety();
	location2.Getx();
	location2.Gety();
	distance2(location1,location2);
	
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值