IT技术博客大学习 共学习 共进步
全部 移动开发 后端 数据库 AI 算法 安全 DevOps 前端 设计 开发者

算法复杂度求法初学

铭扬工作室Blog 2009-11-12 00:03:02 累计浏览 2,596 次
本机暂存

    参考:http://www.comp.nus.edu.sg/~xujia/mirror/algorithm.myrice.com/algorithm/

    有空演习了一点点。

    递归方程算法复杂性求法之:迭代法

    注:T()函数等于php中的floor()函数

    1、T(n) = n^2 + 2T(n/2)

    n^2 + 2T(n/2)

    n^2 + (n/2)^2 + 2T(n/4)

    n^2 + (n/2)^2 + (n/4)^2 + 2T(n/8)

    …

    n^2 + (n/2)^2 + (n/4)^2 + (n/8)^2 + (n/16)^2 + … + (n/2^(2i))^2 + 2T(n/2^(2i))

    n^2(1 + 1/2^2 + 1/2^4 + 1/2^6 + …)

    渐进 = n^2

    2、T(n) = n + T([n/3])+ T([2n/3])

    n + T(n/3)+ T(2n/3)

    n + n/3 + T(n/3^2) + T(2n/3^2) + 2n/3 + T(2n/3^2) + T(n(2/3)^2)

    = 2n + …(4 items)

    2n + n/3^2 + 2n/3^2 + 2n/3^2 + n(2/3)^2 + (8 items)

    = 3n + …(8 items)

    …

    in + (2^i items)

    i为递归次数,有限。items最后都趋于0。

    i是多少次?取决于每次的最大值。每次的最大值分别是:n,n(2/3),n(2/3)^2,n(2/3)3,…,1

    i=log(3/2)n

    渐进 = log(3/2)n * n

同分类推荐文章

  1. 对基本有序的序列排序算法 (2026-06-11 17:46:49)
  2. Four Levels Of Customer Understanding (2026-05-22 21:00:00)
  3. 除法的意义 (2026-04-12 20:52:17)

查看更多 算法 文章 →

建议继续学习

  1. 使用gettext来支持PHP的多语言 (累计阅读 39,267)
  2. WordPress插件开发 -- 在插件使用数据库存储数据 (累计阅读 29,162)
  3. Paypal接口详细代码(PHP版,非API接口) (累计阅读 19,407)
  4. 我的PHP,Python和Ruby之路 (累计阅读 13,146)
  5. include(“./file.php”)和include(“file.php”)区别 (累计阅读 12,788)
  6. 15个最好的免费开源电子商务平台 (累计阅读 12,539)
  7. Redis消息队列的若干实现方式 (累计阅读 12,085)
  8. 到底什么是MVC? (累计阅读 11,864)
  9. 整理了一份招PHP高级工程师的面试题 (累计阅读 11,708)
  10. Rolling cURL: PHP并发最佳实践 (累计阅读 11,486)