1201: 圆的交点

题目描述

输入两个圆的坐标和半径,判断它们是否有交点

输入

第一行输入三个实数x1, y1, r表示第一个圆的坐标和半径,同理第二行输入三个数表示第二个圆的坐标和半径

输出

如果有交点输出”Yes“,否则输出”No"(不带双引号)

样例输入 复制
0 0 5
10 0 5
样例输出 复制
Yes
提示

注意:相切也算有交点

代码:

#include <bits/stdc++.h>
using namespace std;
using i64 = int64_t;
constexpr i64 mod = 998244353;

int main() {
    ios::sync_with_stdio(false);
    cin.tie(nullptr);
     long double x1,y1,r1,x2,y2,r2,R;
     long double distance;
     cin>>x1>>y1>>r1;
     cin>>x2>>y2>>r2;
     distance=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
     R=r1+r2;
     if(distance<=R&&distance>fabs(r1-r2))
     cout<<"Yes";
     else if(distance>=fabs(r1-r2))      //一个圆在另一个圆内相交(相切)
     cout<<"Yes";
    else
     cout<<"No";
     return 0;
}

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值