如何确定平面上两个多边形的重合区域?

zzd 2002-07-15 09:51:36
一个平面上有2个n边形区域(3<n<200),已知所有顶点的坐标。问:如何确定这两个多边形区域是否有重合部分,如果有,如何确定重合区域的顶点坐标?
...全文
660 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
zzwu 2002-07-18
  • 打赏
  • 举报
回复
这一问题我实际编写过一个软件,有点繁.
dukeham 2002-07-18
  • 打赏
  • 举报
回复
将你的多边形用同样大的矩阵表示,多边形内用1表示,外用0表示,
两个或多个矩阵作逻辑与(and)运算所得的矩阵表示两个或多个多边形
重叠的部分。
顶点坐标-----考虑中
愚鬼 2002-07-18
  • 打赏
  • 举报
回复
用颜色试一试:

首先在白板上画出一个多边形区域,并将其涂上一种已知颜色,注意,多边形的边的颜色一定不要与所涂颜色一致。然后再画另一多边形并涂以另一颜色,涂色和画线时要用异或方式。此时图片重叠区域应该有不同的颜色,并交叉的顶点有另外的颜色。剩下的你自己应该会处理了。
devouer 2002-07-18
  • 打赏
  • 举报
回复
在做GIS时我曾经做个关于两个图形合并的问题,是挺复杂的,由于采用的是线形存储坐标点,所以还设计一个画图的方向问题。以下是我的算法:
当然针对凸的,对于非凸的判定情况与此差不多
1)判断两个图形的旋转方向(只有顺时针和逆时针两种)
2)求出所有的交点。
3)将所有的顶点与交点重新构成一个数组(因为所需点可能是顶点)。
4)指定旋转方向提取出按顺序的点构成重合部分。
对于第3,4 步还有问题是在旋转方向上如果一条线段出现二个以上交点会产生问题,于是可以增加辅助点来完成。
许野平 2002-07-16
  • 打赏
  • 举报
回复
其实这个算法和三维图形隐匿线算法差不多,应该是很复杂的。如果是点阵图像,应该有很简单的算法。这里我简单介绍一下两个凸n边形的算法思路:
1)设两个凸多边形A:a1a2a3...am和B:b1b2b3...bn
2)求出A在B内的顶点{ar,as,...}
3) 求出B在A内的顶点{bp,bq,...}
4) 上面的两个点集构成了公共区域多边形的部分顶点
5)求两个多边形的两个交点,很容易判断,略去
对于非凸多边形的情形,可以分解成若干个凸多边形的情况。原理和上面一样。
frman 2002-07-16
  • 打赏
  • 举报
回复
求交点了哦。。。。。。。。
everloveit 2002-07-16
  • 打赏
  • 举报
回复

根据坐标,就可以啦!!
你都知道它的坐标,就好计算啦!
laughcry2002 2002-07-16
  • 打赏
  • 举报
回复
参阅下书, P139
周培德,卢开澄,<计算几何----算法分析与设计>,清华大学出版社,广西科学技术出版社,1999
zzd 2002-07-16
  • 打赏
  • 举报
回复
顶一顶,看看还有什么好办法?
hintel 2002-07-15
  • 打赏
  • 举报
回复
简单点的:判断两个平行于坐标轴的矩形是否有重合。
我写了一个算法,大体与yanghuajia所说的相似,太过烦琐。
有好的算法
yanghuajia 2002-07-15
  • 打赏
  • 举报
回复
最差的想法:1。任意两边是否有交点;(记录交点)2 。判断一个多边形的点是否在另一个多边形内(记录点的位置) 3。再交换判断一个多边形的点是否在另一个多边形内(记录点的位置) 。

都没有,OK!.
如果有:所有的点构成重合区域的顶点坐标

注意:边界判断!
目录 ㈠ 点的基本运算 1. 平面上两点之间距离 1 2. 判断两点是否重合 1 3. 矢量叉乘 1 4. 矢量点乘 2 5. 判断点是否在线段上 2 6. 求一点饶某点旋转后的坐标 2 7. 求矢量夹角 2 ㈡ 线段及直线的基本运算 1. 点与线段的关系 3 2. 求点到线段所在直线垂线的垂足 4 3. 点到线段的最近点 4 4. 点到线段所在直线的距离 4 5. 点到折线集的最近距离 4 6. 判断圆是否在多边形内 5 7. 求矢量夹角余弦 5 8. 求线段之间的夹角 5 9. 判断线段是否相交 6 10.判断线段是否相交但不交在端点处 6 11.求线段所在直线的方程 6 12.求直线的斜率 7 13.求直线的倾斜角 7 14.求点关于某直线的对称点 7 15.判断两条直线是否相交及求直线交点 7 16.判断线段是否相交,如果相交返回交点 7 ㈢ 多边形常用算法模块 1. 判断多边形是否简单多边形 8 2. 检查多边形顶点的凸凹性 9 3. 判断多边形是否凸多边形 9 4. 求多边形面积 9 5. 判断多边形顶点的排列方向,方法一 10 6. 判断多边形顶点的排列方向,方法二 10 7. 射线法判断点是否在多边形内 10 8. 判断点是否在凸多边形内 11 9. 寻找点集的graham算法 12 10.寻找点集凸包的卷包裹法 13 11.判断线段是否在多边形内 14 12.求简单多边形的重心 15 13.求凸多边形的重心 17 14.求肯定在给定多边形内的一个点 17 15.求从多边形外一点出发到该多边形的切线 18 16.判断多边形的核是否存在 19 ㈣ 圆的基本运算 1 .点是否在圆内 20 2 .求不共线的三点所确定的圆 21 ㈤ 矩形的基本运算 1.已知矩形三点坐标,求第4点坐标 22 ㈥ 常用算法的描述 22 ㈦ 补充 1.两圆关系: 24 2.判断圆是否在矩形内: 24 3.点到平面的距离: 25 4.点是否在直线同侧: 25 5.镜面反射线: 25 6.矩形包含: 26 7.两圆交点: 27 8.两圆公共面积: 28 9. 圆和直线关系: 29 10. 内切圆: 30 11. 求切点: 31 12. 线段的左右旋: 31 13.公式: 32
㈠ 点的基本运算 1. 平面上两点之间距离 1 2. 判断两点是否重合 1 3. 矢量叉乘 1 4. 矢量点乘 2 5. 判断点是否在线段上 2 6. 求一点饶某点旋转后的坐标 2 7. 求矢量夹角 2 ㈡ 线段及直线的基本运算 1. 点与线段的关系 3 2. 求点到线段所在直线垂线的垂足 4 3. 点到线段的最近点 4 4. 点到线段所在直线的距离 4 5. 点到折线集的最近距离 4 6. 判断圆是否在多边形内 5 7. 求矢量夹角余弦 5 8. 求线段之间的夹角 5 9. 判断线段是否相交 6 10.判断线段是否相交但不交在端点处 6 11.求线段所在直线的方程 6 12.求直线的斜率 7 13.求直线的倾斜角 7 14.求点关于某直线的对称点 7 15.判断两条直线是否相交及求直线交点 7 16.判断线段是否相交,如果相交返回交点 7 ㈢ 多边形常用算法模块 1. 判断多边形是否简单多边形 8 2. 检查多边形顶点的凸凹性 9 3. 判断多边形是否凸多边形 9 4. 求多边形面积 9 5. 判断多边形顶点的排列方向,方法一 10 6. 判断多边形顶点的排列方向,方法二 10 7. 射线法判断点是否在多边形内 10 8. 判断点是否在凸多边形内 11 9. 寻找点集的graham算法 12 10.寻找点集凸包的卷包裹法 13 11.判断线段是否在多边形内 14 12.求简单多边形的重心 15 13.求凸多边形的重心 17 14.求肯定在给定多边形内的一个点 17 15.求从多边形外一点出发到该多边形的切线 18 16.判断多边形的核是否存在 19 ㈣ 圆的基本运算 1 .点是否在圆内 20 2 .求不共线的三点所确定的圆 21 ㈤ 矩形的基本运算 1.已知矩形三点坐标,求第4点坐标 22 ㈥ 常用算法的描述 22 ㈦ 补充 1.两圆关系: 24 2.判断圆是否在矩形内: 24 3.点到平面的距离: 25 4.点是否在直线同侧: 25 5.镜面反射线: 25 6.矩形包含: 26 7.两圆交点: 27 8.两圆公共面积: 28 9. 圆和直线关系: 29 10. 内切圆: 30 11. 求切点: 31 12. 线段的左右旋: 31
计算几何算法(含源代码) ㈠ 点的基本运算 1. 平面上两点之间距离 1 2. 判断两点是否重合 1 3. 矢量叉乘 1 4. 矢量点乘 2 5. 判断点是否在线段上 2 6. 求一点饶某点旋转后的坐标 2 7. 求矢量夹角 2 ㈡ 线段及直线的基本运算 1. 点与线段的关系 3 2. 求点到线段所在直线垂线的垂足 4 3. 点到线段的最近点 4 4. 点到线段所在直线的距离 4 5. 点到折线集的最近距离 4 6. 判断圆是否在多边形内 5 7. 求矢量夹角余弦 5 8. 求线段之间的夹角 5 9. 判断线段是否相交 6 10.判断线段是否相交但不交在端点处 6 11.求线段所在直线的方程 6 12.求直线的斜率 7 13.求直线的倾斜角 7 14.求点关于某直线的对称点 7 15.判断两条直线是否相交及求直线交点 7 16.判断线段是否相交,如果相交返回交点 7 ㈢ 多边形常用算法模块 1. 判断多边形是否简单多边形 8 2. 检查多边形顶点的凸凹性 9 3. 判断多边形是否凸多边形 9 4. 求多边形面积 9 5. 判断多边形顶点的排列方向,方法一 10 6. 判断多边形顶点的排列方向,方法二 10 7. 射线法判断点是否在多边形内 10 8. 判断点是否在凸多边形内 11 9. 寻找点集的graham算法 12 10.寻找点集凸包的卷包裹法 13 11.判断线段是否在多边形内 14 12.求简单多边形的重心 15 13.求凸多边形的重心 17 14.求肯定在给定多边形内的一个点 17 15.求从多边形外一点出发到该多边形的切线 18 16.判断多边形的核是否存在 19 ㈣ 圆的基本运算 1 .点是否在圆内 20 2 .求不共线的三点所确定的圆 21 ㈤ 矩形的基本运算 1.已知矩形三点坐标,求第4点坐标 22 ㈥ 常用算法的描述 22 ㈦ 补充 1.两圆关系: 24 2.判断圆是否在矩形内: 24 3.点到平面的距离: 25 4.点是否在直线同侧: 25 5.镜面反射线: 25 6.矩形包含: 26 7.两圆交点: 27 8.两圆公共面积: 28 9. 圆和直线关系: 29 10. 内切圆: 30 11. 求切点: 31 12. 线段的左右旋: 31 13.公式: 32

33,008

社区成员

发帖
与我相关
我的任务
社区描述
数据结构与算法相关内容讨论专区
社区管理员
  • 数据结构与算法社区
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧