美文网首页
算法复杂度分析方法

算法复杂度分析方法

作者: lunaSun | 来源:发表于2019-03-04 15:59 被阅读1次

    时间复杂度的全称是渐进时间复杂度,表示算法的执行时间与数据规模之间的增长关系。

    三点原则:
    1. 只关注循环执行次数最多的一段代码

    大 O 这种复杂度表示方法只是表示一种变化趋势。我们通常会忽略掉公式中的常量、低阶、系数,只需要记录一个最大阶的量级就可以了。所以,我们在分析一个算法、一段代码的时间复杂度的时候,也只关注循环执行次数最多的那一段代码就可以了。

    2. 加法法则:总复杂度等于量级最大的那段代码的复杂度

    代码中有多段循环代码,选取量级最大的那段为标准。

    3. 乘法法则:嵌套代码的复杂度等于嵌套内外代码复杂度的乘积`

    与加法法则不同,有嵌套的情况,复杂度应为乘积。

    间复杂度全称就是渐进空间复杂度(asymptotic space complexity),表示算法的存储空间与数据规模之间的增长关系。

    空间复杂度较时间复杂度来说要简单得多,只看要分析的代码分配了占用多少空间的变量即可,常见的空间复杂度就是 O(1)、O(n)、O(n2 ),对数阶的复杂度平时很少见。

    相关文章

      网友评论

          本文标题:算法复杂度分析方法

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