It is well known that the convex hull of a set of n points in the (Euclidean) plane can be found by an algorithm having worst-case complexity O(n log n). In this note we give a short linear algorithm for finding the convex hull in the, case that the (ordered) set of points from the vertices of a simple (i.e., non-self-intersecting) polygon.
ftp://reports.stanford.edu/pub/cstr/reports/cs/tr/81/887/CS-TR-81-887.pdf
http://deepblue.lib.umich.edu/bitstream/2027.42/7588/5/bam3301.0001.001.pdf
We present space-efficient algorithms for computing the convex hull of a simple polygonal line in-place, in linear time. It turns out that the problem is as hard as stable partition, i.e., if there were a truly simple solution then stable partition would also have a truly simple solution, and vice versa. Nevertheless, we present a simple self-contained solution that uses O(log n) space, and indicate how to improve it to O(1) space with the same techniques used for stable partition. If the points inside the convex hull can be discarded, then there is a truly simple solution that uses a single call to stable partition, and even that call can be spared if only extreme points are desired (and not their order). If the polygonal line is closed, then the problem admits a very simple solution which does not call for stable partitioning at all.
http://springerlink.metapress.com/content/5clwpcjenldf5a78/fulltext.pdf
'Computational Geometry' 카테고리의 다른 글
3개의 숫자 중에서 가장 큰 것은 (0) | 2012.01.17 |
---|---|
소금 호수에 생긴 보로노이 다이어그램 (1) | 2010.11.06 |
한 점에서 선분까지 거리 (1) | 2010.01.16 |
삼각형 채우기 (0) | 2009.12.19 |
Triangulation을 이용한 Imge Effect (0) | 2009.12.18 |