c语言 判断直线与圆的位置关系 急! 30

Description两点确定一条直线,判断一条直线与一个圆的位置关系。Input输入中前两行每行描述一个点的坐标(x,y),x,y均为实数。第三行包含三个实数,即圆心坐... Description
两点确定一条直线,判断一条直线与一个圆的位置关系。

Input
输入中前两行每行描述一个点的坐标(x,y),x,y均为实数。
第三行包含三个实数,即圆心坐标和圆的半径R>0。

Output
输出包含三种情况,计算误差应在1e-3(0.001)内。
“Interseetion”(相交时输出);
“Tangency”(相切时输出);
“Disjoint”(相离时输出);
以上输出不含引号。
Sample Input
1 0
0 1
0 0 1
Sample Output
Interseetion
HINT

回忆中学的几何知识,最好能自己先想到此题的几何解,实在想不到,可以查查法线方程之类的,然后用程序实现。这里要用到浮点数的精度控制。
展开
 我来答
百度网友d580670
推荐于2017-06-30 · TA获得超过1983个赞
知道大有可为答主
回答量:2054
采纳率:82%
帮助的人:705万
展开全部
typedef struct{
float x;
float y;
}POINT;
typedef struct{
POINT a;
POINT b;
}LINE;
typedef struct{
POINT c;
float r;
}CIRCLE;
int relation(LINE* l, CIRCLE* c)
{
float dist
= fabs((l->a.x-l->b.x)*c->c.y - (l->a.y-l->b.y)*c->c.x - l->b.y*l->a.x + l->b.x*l->a.y)/
  sqrt((l->a.x-l->b.x)*(l->a.x-l->b.x) + (l->a.y-l->b.y)*(l->a.y-l->b.y));
if (dist == c->r) {
printf("Tangency\n");
}
else if (dist > c->r) {
printf("Disjoint\n");
}
else {
printf("Interseetion\n");
}
return 0;
}
追问
编译不通过啊
天马流星E
2015-11-18
知道答主
回答量:30
采纳率:0%
帮助的人:7.7万
展开全部
山科大的吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
程杰5278
2015-11-14
知道答主
回答量:14
采纳率:0%
帮助的人:3.6万
展开全部
相交 相切 相离
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 2条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式