#include <stdio.h>
#include <math.h>
int main()
{
double x1, y1, r1, x2, y2, r2, d;
while (scanf("%lf%lf%lf", &x1, &y1, &r1), scanf("%lf%lf%lf", &x2, &y2, &r2) != EOF)
{
d = sqrt(fabs(x1 - x2) * fabs(x1 - x2) + fabs(y1 - y2) * fabs(y1 - y2));
if (d > r1 + r2)
{
printf("disjoint\n");
}
else if (fabs(r1 - r2) < d)
{
printf("contain\n");
}
else if (fabs(r1 - r2) == d)
{
printf("internally tangent\n");
}
else if (r1 + r2 == d)
{
printf("externally tangent\n");
}
else if (d > fabs(r1 - r2) && d < fabs(r1 + r2))
{
printf("overlap\n");
}
}
return 0;
}
输入0.5 5.1 13 1 1.7 4.5这组数据为什么输出不了
- 写回答
- 好问题 0 提建议
- 追加酬金
- 关注问题
- 邀请回答
-
2条回答 默认 最新
- qfl_sdu 2021-10-12 14:16关注
逻辑有问题,代码修改如下:
#include <stdio.h> #include <math.h> int main() { double x1, y1, r1, x2, y2, r2, d; while (scanf("%lf%lf%lf", &x1, &y1, &r1), scanf("%lf%lf%lf", &x2, &y2, &r2) != EOF) { d = sqrt(fabs(x1 - x2) * fabs(x1 - x2) + fabs(y1 - y2) * fabs(y1 - y2)); if (d > r1 + r2) { printf("disjoint\n"); }else if (r1 + r2 == d) { printf("externally tangent\n"); }else { if (fabs(r1 - r2) < d) { printf("contain\n"); } else if (fabs(r1 - r2) == d) { printf("internally tangent\n"); } else { printf("overlap\n"); } } } return 0; }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报
悬赏问题
- ¥15 目详情-五一模拟赛详情页
- ¥15 有了解d3和topogram.js库的吗?有偿请教
- ¥100 任意维数的K均值聚类
- ¥15 stamps做sbas-insar,时序沉降图怎么画
- ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
- ¥15 关于#Java#的问题,如何解决?
- ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
- ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
- ¥15 cmd cl 0x000007b
- ¥20 BAPI_PR_CHANGE how to add account assignment information for service line