快速排斥实验amp;跨立实验 判断两直线是否相交
两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的。
也就是说线段不严格相交时可以将端点作为交点,但本文不讨论不严格相交,只讨论严格相交的情况(即使它们在算法实现上差别不大)。
在判断两条线段是否相交时,我们常用快速排斥实验跟跨立实验这两种方法,快速排斥实验能很快的排除掉线段不相交的情况,但并没法成为线段相交的充要条件,在快速排斥实验之后接上跨立实验就能完全的判断两线段是否相交,但其实只用跨立实验这一种办法也能作为判断线段相交的充要条件。
1.快速排斥实验:
假设以线段P1,P2为对角线作一矩形R,再以Q1,Q2为对角线作矩形T,当两个矩形不相交的时候两条线段肯定不相交,即线段相交的必要条件时矩形相交。
2.跨立实验:
若(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.快速排序实验 两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的.快速排斥实验能很快的排除掉线段不相交的情况,但并没法成为线段相交的充要条件,在快速排斥实验之后 ...
- 计算几何——快速排斥实验和跨立实验
两条线段有且仅有一个公共点,且这个点不是任何一条线段的端点时,称这两条线段是严格相交的. 也就是说线段不严格相交时可以将端点作为交点,但本文不讨论不严格相交,只讨论严格相交的情况(即使它们在算法实现上 ...
- POJ1410线段相交、快速排斥实验、跨立实验
题目 Intersection 给出二维平面中一条线段和一个矩形,问线段和矩形是否有交点,矩形包括边和内部. 解题思路 先判断线段和四条边是否相交,如果没交点,再继续判断线段是否在矩形内. 判断线段相 ...
- 快速排斥实验和跨立实验
矢量 如果一条线段的端点是有次序之分的话,那么这种线段就称为 有向线段,如果有向线段p1p2的起点p1在坐标的原点,则可以把它称为矢量p2 矢量的加减 设二维矢量 P = (x1, y1), Q = ...
- 【代码超详解】ZOJ 2551 / POJ 2653 Pick-up Sticks(快速排斥实验 + 跨立实验判断线段是否相交 · 模板)
一.传送门 http://poj.org/problem?id=2653 https://zoj.pintia.cn/problem-sets/91827364500/problems/9182736 ...
- POJ - 1269 Intersecting Lines(计算几何 + 叉积 + 跨立实验)
链接 Intersecting Lines 题意 给出两条线段,判断是否共线,平行,或者相交,如果相交输出交点: 思路 如何判断共线: 我们知道两个向量叉积为 000,两向量共线: 所以我们只需要判断 ...
- 判断两线段是否相交——快速排斥与跨立实验
如何判断两条线段是否相交呢?如果是我们去解决这个问题,用眼睛很容易就看出来了,但是如果用计算机来解决这个问题,该怎么办呢?下面介绍两个方法,这两个方法结合起来就能完美解决这个问题了. 一.快速排斥 对 ...
- 快速排斥、跨立实验判断线段是否相交
写在前面 在其他博客中看到这方面的知识,很多都是重复,并且说的总是云里雾里的,所以这里我就自己总结一下这种问题如何求解,判断两个线段是否相交在前面我们提到了会用到叉积的一点知识,那么这里就来详细说一下 ...
最新文章
- 10个重构小技巧,去掉代码中的S味
- const和readonly内部区别
- 有图有真相!这世界上,竟有人跟你长得一模一样!
- 存放80000000学生成绩的集合,怎么统计平均分性能高
- 记录请求的耗时(拦截器、过滤器、aspect)
- 深入理解CRITICAL_SECTION
- sklearn之Multioutput 估计器
- 搭建centos在线yum源镜像服务器,搭建CentOS在线yum源镜像服务器(上)
- 通信值勤维护管理条例_加强固定通信台站值勤管理与建设
- python图像转矩阵_python 图像转矩阵,矩阵转图像
- python打开word内对象_Python操作Word:常用对象介绍
- c语言有flag的程序,c语言flag(编程flag的用法)
- MyEclipse 使用教程
- 数据挖掘 顶级期刊_澳大利亚麦考瑞大学, 国际数据挖掘顶级期刊ACM TKDD副主编招收5名数据挖掘全奖PhD...
- set在python中是什么意思_python中set是什么意思
- 县城中学计算机教师就业难吗,我县中小学信息技术教师现状及对策
- 解决 mac 蓝牙鼠标、键盘经常总是 断开连接的问题
- Webpack(打包工具)
- 如何有效地召开会议?
- java web第三章 Day3 2020080605018