美文网首页
建堆O(n)时间复杂度证明

建堆O(n)时间复杂度证明

作者: 胡哈哈哈 | 来源:发表于2016-05-21 15:02 被阅读1272次

建堆复杂度先考虑满二叉树,计算完全二叉树建堆复杂度基本相同。

对满二叉树而言,第i层(根为第0层)有2^i个节点。由于建堆过程自底向上,以交换作为主要操作,因此第i层任意节点在最不利情况下,需要经过(n-i)次交换操作才能完成以该节点为堆根节点的建堆过程。因此,时间复杂度计算如下:

T(n) = 2^0 * (n - 0) + 2^1 * (n - 1) + ... + 2^n * (n - n) = sum((n - i) * 2^i)

采用错位相减法:

  • 原式乘2得:
  • T(n) * 2 = 2^1 * (n - 0) + 2^2 * (n - 1) + ... + 2^(n+1) * (n - n)
  • = sum((n - i) * 2^(i+1))
  • 原式如下:
  • T(n) = 2^0 * (n - 0) + 2^1 * (n - 1) + ... + 2^n * (n - n)
  • = sum((n - i) * 2^i)
  • 相减得:
  • 2T(n) - T(n) = -n + 2^1 + 2^2 + ... + 2^n = 2 * (1 - 2^n) / (1 - 2) - n
  • = 2^(n+1) - 2 - n

上面推导中,n为层数编号(自0层根节点开始)。故总节点数为(1 + 2 + 4 + ... + 2^n) = 2^(n+1) - 1。渐进时,忽略减1取N = 2^(n+1)

T(N) = 2^(n+1) - n - 2 = N * (1 - logN / N - 2 / N) ≈ N

故时间复杂度为O(N),得证。

相关文章

  • 建堆O(n)时间复杂度证明

    建堆复杂度先考虑满二叉树,计算完全二叉树建堆复杂度基本相同。 对满二叉树而言,第i层(根为第0层)有2^i个节点。...

  • 建堆时间复杂度的计算

    建堆时间复杂度的计算 建堆的方式有两种,比较常见的建堆方式是自底向上,因为时间复杂度更低,为O(N). 自顶向下的...

  • 时间复杂度 空间复杂度

    时间复杂度: O(n) O(n²) 空间复杂度 O(n) O(n²)

  • 快速排序 by Python

    最好时间复杂度:O(n*logn)最坏时间复杂度:O(n²)平均时间复杂度:O(n*logn)空间复杂度:O(1)...

  • 最新BAT的实习面经

    一、今日头条:后台开发面经 一面,比较基础 自我介绍 实习经历 HashMap 堆排,建堆的时间复杂度,O(n),...

  • 每日一题20201106(169. 多数元素)

    hash表 时间复杂度: O(N)空间复杂度: O(N) 投票算法 时间复杂度: O(N)空间复杂度: O(1)

  • 选择排序 by Python

    最好时间复杂度:O(n²)最坏时间复杂度:O(n²)平均时间复杂度:O(n²)空间复杂度:O(1)是否是稳定排序:...

  • 归并排序 by Python

    最好时间复杂度:O(n*logn)最坏时间复杂度:O(n*logn)平均时间复杂度:O(n*logn)空间复杂度:...

  • 归并排序图解

    平均时间复杂度:O(nlogn) 最佳时间复杂度:O(n) 最差时间复杂度:O(nlogn) 空间复杂度:O(n)...

  • 冒泡排序 by Python

    最好时间复杂度:O(n)最坏时间复杂度:O(n²)平均时间复杂度:O(n²)空间复杂度:O(1)是否为稳定排序:Y...

网友评论

      本文标题:建堆O(n)时间复杂度证明

      本文链接:https://www.haomeiwen.com/subject/yjqorttx.html