求两条线段的交点java_求两条线段的交点

这是一个使用Java实现的求两条线段交点的算法,包括计算线段的交点坐标并检查交点是否在线段范围内。算法还包含一个主函数,用于处理多个线段并计算没有交点的线段对数量。
摘要由CSDN通过智能技术生成

#include

#define ll long long

using namespace std;

struct Point{

ll x,y;

Point(ll x=0,ll y=0):x(x),y(y){};

};

ll gcd(ll a,ll b)

{

return a==0?b:gcd(b%a,a);

}

bool cheak(ll op1,ll a,ll b){

if(a>b)

swap(a,b);

return op1>=a&&op1<=b;

}

Point point_of_intersection(Point f1,Point f2,Point f3,Point f4,bool &mark)

{

ll a1,a2,b1,b2,c1,c2,c3,c4,D,D1,D2;

a1=f2.y-f1.y;

a2=f1.x-f2.x;

b1=a1*f1.x+a2*f1.y;

///b1=(y2-y1)*x1+(x1-x2)*y1

c1=f4.y-f3.y;

c2=f3.x-f4.x;

b2=c1*f3.x+c2*f3.y;

///b2=(y4-y3)*x3+(x3-x4)*y3

c3=f2.x-f1.x;

c4=f4.x-f3.x;

D=c3*c1-c4*a1;

Point res;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值