我知道复杂度是 O(nlog(n))。但为什么?你是怎么得出这个答案的?
任何帮助将不胜感激,我很想知道!
我知道复杂度是 O(nlog(n))。但为什么?你是怎么得出这个答案的?
任何帮助将不胜感激,我很想知道!
它的平均情况复杂度被认为是O(n log(n))
,而在最坏的情况下它需要O(n^2)
(二次)。
考虑以下伪代码:
QuickHull (S, l, r)
if S={ } then return ()
else if S={l, r} then return (l, r) // a single convex hull edge
else
z = index of a point that is furthest (max distance) from xy.
Let A be the set containing points strictly right of (x, z)
Let B be the set containing points strictly right of (z, y)
return {QuickHull (A, x, z) U (z) U QuickHull (B, z, y)}
分区由通过两个不同极值点的线确定:最右边的最低点r
和最左边的最高点l
。找到极端需要O(n)
时间。
对于递归函数,它需要n
一些步骤来确定极值点z
,但递归调用的成本取决于 setA
和 set的大小B
。
最好的情况。考虑最好的情况,即每个分区几乎是平衡的。然后我们有
T(n) = 2 T(n/2) + O(n)
.
这是一个熟悉的递归关系,其解是
T(n) = O(n log(n))
.
这将发生在随机分布的点上。
最坏的情况下。最坏的情况发生在每个分区都非常不平衡时。在这种情况下,递归关系是
T(n) = T(n-1) + O(n)
= T(n-1) + cn
反复展开表明这是O(n^2)
. 因此,在最坏的情况下,QuickHull 是二次方的。
http://www.personal.kent.edu/~rmuhamma/Compgeometry/MyCG/ConvexHull/quickHull.htm