基本问题:
平面上有n个点p1,p2, ..., pn, 要求求出一个面积最小的凸多边形,使得这个多边形包含所有平面上的点。
根据算法导论上提供的两个方法做一些介绍:
算法1:
Graham扫描法
下面直接给出一段伪代码,方便描述:
最后S栈中保存了所有凸多边形的顶点集合
下面用图示表示一下算法的过程:
1.初始化所有的p0,p1,...pn-1
2. p0,p1,p2入栈
3. 这时候栈顶元素是p2,次栈顶元素p1, 枚举p3, 那么可以看出, p2->p3的向量相对于p2->p1的向量是向右走的,所以栈中弹出p2, 压入p3
4. P4入栈,由于栈顶元素是p3,次栈顶元素是p1, 那么p3->p4向量,相对于p1->p3向量是向左走的,所以压入p4
5.由于栈顶元素是p4,次栈顶元素是p3, 那么p4->p5向量,相对于p3->p4向量是向右走的,所以弹出p4,压入p5