凸包
(只针对二维平面内的凸包)
一、定义
简单的说,在一个二维平面内有n个点的集合S,现在要你选择一个点集C,C中的点构成一个凸多边形G,使得S集合的所有点要么在G内,要么在G上,并且保证这个凸多边形的面积最小,我们要求的就是这个C集合。
二、算法
求凸包的算法很多,常用的有两种:
1. Graham扫描法,运行时间为O(nlgn)。
2. Jarvis步进法,运行时间为O(nh),h为凸包中的顶点数。
这里主要讨论第一种算法:Graham扫描法
Graham扫描法:
基本思想:使用一个栈来对所有点逐一判断,把不符合条件的点筛出去。
操作:输入集合Q中的每一个点都被压入栈一次,非CH(