技术头条 - 一个快速在微博传播文章的方式     搜索本站
您现在的位置首页 --> 算法 --> 算法复杂度求法初学

算法复杂度求法初学

浏览:1647次  出处信息

    参考: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. 降低样式计算的范围和复杂度    (阅读:963)
QQ技术交流群:445447336,欢迎加入!
扫一扫订阅我的微信号:IT技术博客大学习
© 2009 - 2025 by blogread.cn 微博:@IT技术博客大学习

京ICP备15002552号-1