两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的。

也就是说线段不严格相交时可以将端点作为交点,但本文不讨论不严格相交,只讨论严格相交的情况(即使它们在算法实现上差别不大)。

在判断两条线段是否相交时,我们常用快速排斥实验跟跨立实验这两种方法,快速排斥实验能很快的排除掉线段不相交的情况,但并没法成为线段相交的充要条件,在快速排斥实验之后接上跨立实验就能完全的判断两线段是否相交,但其实只用跨立实验这一种办法也能作为判断线段相交的充要条件。

1.快速排斥实验:

假设以线段P1,P2为对角线作一矩形R,再以Q1,Q2为对角线作矩形T,当两个矩形不相交的时候两条线段肯定不相交,即线段相交的必要条件时矩形相交。

2.跨立实验:

若P1P2跨立Q1Q2,即向量Q1P1和向量Q1P2分布向量Q1Q2的两侧,满足(P1−Q1)×(Q2−Q1)∗(P2−Q1)×(Q2−Q1)<0。
若(P1−Q1)×(Q2−Q1)∗(P2−Q1)×(Q2−Q1)=0,说明P1或P2在直线Q1Q2上,但因为已通过快速排斥试验,所以这两线段是相交的。
故上式可改写成 (P1−Q1)×(Q2−Q1)∗(P2−Q1)×(Q2−Q1)≤0
同理,若Q1Q2跨立P1P2,则要满足(Q1−P1)×(P2−P1)∗(Q2−P1)×(P2−P1)≤0
当P1P2跨立Q1Q2且Q1Q2跨立P1P2,跨立试验成功。
struct point{double x,y;
}P1,P2,Q1,Q2;
struct Edge
{point a,b;
}e[N];
double xmult(point a,point b,point c) //大于零代表a,b,c左转
{return (b.x-a.x)*(c.y-a.y)-(b.y-a.y)*(c.x-a.x);
}
bool OnSegment(point a,point b,point c)         //a,b,c共线时有效
{return c.x>=min(a.x,b.x)&&c.x<=max(a.x,b.x)&&c.y>=min(a.y,b.y)&&c.y<=max(a.y,b.y);
}bool Cross(point a,point b,point c,point d) //判断ab 与cd是否相交
{double d1,d2,d3,d4;d1=xmult(c,d,a);d2=xmult(c,d,b);d3=xmult(a,b,c);d4=xmult(a,b,d);if(d1*d2<0&&d3*d4<0)  return 1;else    if(d1==0&&OnSegment(c,d,a)) return 1;else    if(d2==0&&OnSegment(c,d,b)) return 1;else    if(d3==0&&OnSegment(a,b,c)) return 1;else    if(d4==0&&OnSegment(a,b,d)) return 1;return 0;
}

快速排斥实验amp;跨立实验 判断两直线是否相交相关推荐

  1. 计算几何--快速排斥实验和跨立实验

    1.快速排序实验 两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的.快速排斥实验能很快的排除掉线段不相交的情况,但并没法成为线段相交的充要条件,在快速排斥实验之后 ...

  2. 【计算几何】快速排斥实验和跨立实验

    1.快速排序实验 两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的.快速排斥实验能很快的排除掉线段不相交的情况,但并没法成为线段相交的充要条件,在快速排斥实验之后 ...

  3. 计算几何——快速排斥实验和跨立实验

    两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的. 也就是说线段不严格相交时可以将端点作为交点,但本文不讨论不严格相交,只讨论严格相交的情况(即使它们在算法实现上 ...

  4. POJ1410线段相交、快速排斥实验、跨立实验

    题目 Intersection 给出二维平面中一条线段和一个矩形,问线段和矩形是否有交点,矩形包括边和内部. 解题思路 先判断线段和四条边是否相交,如果没交点,再继续判断线段是否在矩形内. 判断线段相 ...

  5. 快速排斥实验和跨立实验

    矢量 如果一条线段的端点是有次序之分的话,那么这种线段就称为 有向线段,如果有向线段p1p2的起点p1在坐标的原点,则可以把它称为矢量p2 矢量的加减 设二维矢量 P = (x1, y1), Q = ...

  6. 【代码超详解】ZOJ 2551 / POJ 2653 Pick-up Sticks(快速排斥实验 + 跨立实验判断线段是否相交 · 模板)

    一.传送门 http://poj.org/problem?id=2653 https://zoj.pintia.cn/problem-sets/91827364500/problems/9182736 ...

  7. POJ - 1269 Intersecting Lines(计算几何 + 叉积 + 跨立实验)

    链接 Intersecting Lines 题意 给出两条线段,判断是否共线,平行,或者相交,如果相交输出交点: 思路 如何判断共线: 我们知道两个向量叉积为 000,两向量共线: 所以我们只需要判断 ...

  8. 判断两线段是否相交——快速排斥与跨立实验

    如何判断两条线段是否相交呢?如果是我们去解决这个问题,用眼睛很容易就看出来了,但是如果用计算机来解决这个问题,该怎么办呢?下面介绍两个方法,这两个方法结合起来就能完美解决这个问题了. 一.快速排斥 对 ...

  9. 快速排斥、跨立实验判断线段是否相交

    写在前面 在其他博客中看到这方面的知识,很多都是重复,并且说的总是云里雾里的,所以这里我就自己总结一下这种问题如何求解,判断两个线段是否相交在前面我们提到了会用到叉积的一点知识,那么这里就来详细说一下 ...

最新文章

  1. 10个重构小技巧,去掉代码中的S味
  2. const和readonly内部区别
  3. 有图有真相!这世界上,竟有人跟你长得一模一样!
  4. 存放80000000学生成绩的集合,怎么统计平均分性能高
  5. 记录请求的耗时(拦截器、过滤器、aspect)
  6. 深入理解CRITICAL_SECTION
  7. sklearn之Multioutput 估计器
  8. 搭建centos在线yum源镜像服务器,搭建CentOS在线yum源镜像服务器(上)
  9. 通信值勤维护管理条例_加强固定通信台站值勤管理与建设
  10. python图像转矩阵_python 图像转矩阵,矩阵转图像
  11. python打开word内对象_Python操作Word:常用对象介绍
  12. c语言有flag的程序,c语言flag(编程flag的用法)
  13. MyEclipse 使用教程
  14. 数据挖掘 顶级期刊_澳大利亚麦考瑞大学, 国际数据挖掘顶级期刊ACM TKDD副主编招收5名数据挖掘全奖PhD...
  15. set在python中是什么意思_python中set是什么意思
  16. 县城中学计算机教师就业难吗,我县中小学信息技术教师现状及对策
  17. 解决 mac 蓝牙鼠标、键盘经常总是 断开连接的问题
  18. Webpack(打包工具)
  19. 如何有效地召开会议?
  20. java web第三章 Day3 2020080605018

热门文章

  1. 一个简单的电商网站秒杀程序的实现
  2. find ctime atime mtime
  3. 小鹏汽车质量 未来的小鹏汽车质量该走的路,一步也不能少!
  4. Reason : image not found
  5. 【牛客网华为机试】HJ88 扑克牌大小
  6. 深入理解JDK动态代理原理,使用javassist动手写一个动态代理框架
  7. C#-TimeSpan格式化字符串格式
  8. 商城系统开发从0到1(sku之设计与实现)
  9. Java代码覆盖率框架JaCoCo的core-instr core.internal.instr 包类源码解析
  10. 朋友推荐的书——《道德经》