【id:56】【20分】A. 距离计算(友元函数)

时间限制
1s
内存限制
128MB

题目描述
Point类的基本形式如下:

class Point
{
private:
double x, y;
public:
Point(double xx, double yy); // 构造函数
};
请完成如下要求:

1.实现Point类;
2.为Point类增加一个友元函数double Distance(Point &a, Point &b),用于计算两点之间的距离。直接访问Point对象的私有数据进行计算。
3.编写main函数,输入两点坐标值,计算两点之间的距离。

输入
第1行:输入需计算距离的点对的数目

第2行开始,每行依次输入两个点的x和y坐标

输出
每行依次输出一组点对之间的距离(结果直接取整数部分,不四舍五入 )

样例查看模式
正常显示
查看格式
输入样例1 <-复制

输出样例1

#include<bits/stdc++.h>
using namespace std;
class Point
{
private:
    double x, y;
public:
    friend double Distance(Point& a, Point& b);
    Point(double xx, double yy) {
        x = xx;
        y = yy;
    } // 构造函数
};
double Distance(Point& a, Point& b) {
    double dis;
    dis = sqrt((a.x-b.x)* (a.x - b.x)+(a.y-b.y)* (a.y - b.y));
    return dis;
}
int main() {
    int t;
    double x1, x2, y1, y2;
    cin >> t;
    while (t--) {
        cin >> x1 >> y1 >> x2 >> y2;
        Point p1(x1, y1);
        Point p2(x2, y2);
        cout <<fixed<<setprecision(0)<< Distance(p1, p2) << endl;
    }

    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

谁的BUG最难改

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值