博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
凸包1——卷包裹算法
阅读量:4325 次
发布时间:2019-06-06

本文共 544 字,大约阅读时间需要 1 分钟。

有了向量 我们就可以选取一个最外侧的点了

 

利用向量 我们可以比较哪个点"更外侧"

比如点K和点I 我们利用向量JK乘以向量JI得到一个数 这个数应该是负数 说明I比K更外侧

两个向量的比较具有传递性 所以我们可以像N个数里取最大的数一样取出最外侧的

遍历所有点 每个点都和现有最外侧的点比较 得到新的最外侧的点

至此两个问题都得以解决 我们可以写出满足一般要求的卷包裹算法了

两个问题如下:

1.怎么确定一个肯定在凸包上的点?

这个问题很好解决 取一个最左边的也就是横坐标最小的点

如果有多个这样的点 就取这些点里 纵坐标最小的

这样可以很好的处理共线的情况

2.如何确定下一个点(即最外侧的点)?

我们需要利用向量的叉积来解决这个问题

 

不过还遗留有一个问题 就是处理共线的问题

有时候我们需要凸包边上的点也考虑到 有时候却需要去掉这些点

我们通常称在凸包顶点处的点为极点

如果我们只要求保留极点而去除在边上的点

我们只需在取外侧的点的时候 碰到共线的点取最远的

相反 如果我们要保留所有在边上的点

我们只需要在共线的点中取最近的

这样整个卷包裹法终于完成了

转载于:https://www.cnblogs.com/o8le/archive/2011/11/15/2250107.html

你可能感兴趣的文章
Hbase记录-client访问zookeeper大量断开以及参数调优分析(转载)
查看>>
2010年ImagineCup,我们共同走过
查看>>
代码片段收集
查看>>
vue-cli3创建项目时报错
查看>>
输入1-53周,输出1-53周的开始时间和结束时间
查看>>
实验二
查看>>
shell——按指定列排序
查看>>
crash 收集
查看>>
Oracle数据库索引使用及索引失效总结
查看>>
507 LOJ 「LibreOJ NOI Round #1」接竹竿
查看>>
UI基础--烟花动画
查看>>
hibernate 批量插入数据
查看>>
2018. 2.4 Java中集合嵌套集合的练习
查看>>
精通ASP.NET Web程序测试
查看>>
vue 根据不同属性 设置背景
查看>>
51Nod1601 完全图的最小生成树计数 Trie Prufer编码
查看>>
Codeforces 1110D. Jongmah 动态规划
查看>>
android驱动在win10系统上安装的心酸历程
查看>>
优雅的程序员
查看>>
oracle之三 自动任务调度
查看>>