gpt4 book ai didi

algorithm - 为什么堆排序不是 lg(n!)?

转载 作者:塔克拉玛干 更新时间:2023-11-03 02:52:15 30 4
gpt4 key购买 nike

我正在阅读 CLRS,它说堆排序是

HEAPSORT(A):
BUILD-MAX-HEAP(A);
for (i = A.length; i >= 1; i++)
{
exchange A[1] with A[i];
A.heap-size = A.heap-size - 1;
MAX-HEAPIFY(A,1);
}

MAX_HEAPIFY 是 O(lg n)。书中说它运行 MAX-HEAPIFY n 次因此它是 O(n lg n) 时间。

但是如果每次迭代堆的大小都缩小 1,它不应该是 O(lg n!) 吗?

应该是 lg 1 + lg 2 ... + lg(n-1) + lg (n) = lg(n!),对吧?

最佳答案

实际上是Stirling's Approximation :

O(log(n!)) = O(nlogn)

关于algorithm - 为什么堆排序不是 lg(n!)?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22901922/

30 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com