java两个圆相交的面积_java判断两圆是否相交以及相交的面积大小。

java判断两圆是否相交以及相交的面积大小。

关注:122  答案:3  信息版本:手机版 电脑版

解决时间 2021-01-31 15:49

提问者一段小時光

2021-01-30 21:28

public class Circle {

double _x;

double _y;

double _r;

Color _c;

Circle(double x,double y,double r,Color c){

_x=x;

_y=y;

_r=r;

_c=c; }

void edgeColor(){

cpDraw.setPenColor(_c);

};

void filledColor(Color fc){

cpDraw.setPenColor(fc);

cpDraw.FilledCircle(_x, _y, _r

);

}

double Area()

{

return Math.PI*_r*_r;

}

以上有Circle函数及求面积的函数,刚刚学JAVA的菜鸟请教各位大大判断两圆相交和相交面积的函数如何写,谢谢~越简单的越好,花哨了看不明白……

最佳答案

二级知识专家無字情書

2021-01-30 22:48

boolean isIntersecting(Circle c){

return Math.sqrt((_x-c._x)*(_x-c._x)+(_y-c._y)*(_y-c._y))<=_r+c._r;

}

double sharedArea(Circle c){

double alpha,area;

double d=Math.sqrt((_x-c._x)*(_x-c._x)+(_y-c._y)*(_y-c._y));//两圆心距离

if(d>_r+c._r){

return 0;

}

alpha=Math.acos((d*d+_r*_r-c._r*c._r)/(2*d*_r));//余弦定理取得相交弧所对本圆的圆心角

area=alpha*_r*_r;//本圆扇形面积

alpha=Math.acos((d*d+c._r*c._r-_r*_r)/(2*d*c._r));//余弦定理取得相交弧所对另一圆的圆心角

area+=alpha*c._r*c._r;//另一圆的扇形面积

double s=(d+_r+c._r)/2;//海伦公式之s

area-=Math.sqrt(s*(s-d)*(s-_r)*(s-c._r))*2;//两扇形面积减去两三角形面积即为交集

return area;

}

全部回答

1楼X謝你的出現

2021-01-31 01:00

你好!

可以判断两圆圆心的距离,如果距离大于两圆的半径之和,这两圆不相交,相反则相交;

求面积则有点麻烦,先求相交两点的夹角,分别求出该夹角对应扇形的面积,然后减去三角形的面积便是相交面积。

希望对你有所帮助,望采纳。

2楼若爱会伤

2021-01-31 00:00

呵呵 ,求面积可以用二个圆的面积可以用一个扇形的面积减去三角形面积X2

我要举报

如以上信息为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!

推荐资讯

大家都在看

实验内容: 一、定义一个名为Circle的类,位于shape包中。要求如下: (1) 该类需要描述在二维坐标系中的位置,心的横、纵坐标值均取整数;描述的半径,取双精度类型。 (2) 无参构造方法将心坐标设为坐标点,半径设为1.0;有参构造方法需要根据参数值设置心坐标和半径值。 (3) 提供一个计算面积的方法double getArea()。 (4) 提供一个判断当前对象与参数对象是否相交的方法(相交方式见下图): boolean isIntersected(Circle another) (5) 提供一个判断当前对象是否包含参数对象的方法(包含方式见下图): boolean contains(Circle another) (6) 提供一个判断当前对象与参数对象的大小关系的方法(判断依据是半径,半径之差的绝对值小于0.0001认为相等;返回负数表示当前对象小,0表示相等,正数表示当前对象) int compareTo(Circle another) (7) 提供返回当前的字符串的方法,格式为:[Circle(x,y)-raduis] String toString() 二、定义一个包含main方法的类TestCircle,位于shape包中。要求如下: (1) main方法中调用以下方法。 (2) 编写静态方法createArray,生成位置和大小均随机的10个对象,置于数组中。 (3) 编写静态方法sort对这10个对象进行升序排序,并输出。 (4) 编写静态方法computeArea计算这10个中互不相交和包含的面积之和。 提交要求:打包为可以执行的JAR文档,其中要包含源程序文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值