zoukankan      html  css  js  c++  java
  • 2015-10-21 算法的时间复杂度和空间复杂度课后总结

    I 算法效率的度量有两种主要的方式:

    1、事后统计法:这种方法可行,但不是一个好的方法。该方法有两个缺陷:一是要想对设计的算法的运行性能进行评测,必须先依据算法编制相应的程序并实际运行;二是所得时间的统计量依赖于计算机的硬件、软件等环境因素,有时容易掩盖算法本身的优势。

    2、事前估计法:在编写程序前,依据统计方法对算法进行估算。

    一个用高级语言编写的程序在计算机上运行时所消耗的时间取决于下列因素:

    (1) 算法采用的策略、方法;

    (2) 编译产生的代码质量;

    (3) 问题的输入规模;

    (4)  机器执行指令的速度。

    II 算法效率的简单估算:

    算法效率简单估计实例1:

    算法效率简单估计实例2:

     

    算法效率简单估计实例3:

    三个实例操作次数分别为:

    2n+5次、n+3次、3次

    随着问题规模n的增大,他们的操作数的数量差异会越来越大!

    判断一个算法效率时,往往只需关注操作数的最高次项,其它次项和常数可以忽略。于是引出了“大O表示法”:

    1、算法效率严重依赖于操作(operation)数量

    2、在判断时首先关注操作数量的最高次项。

    3、操作数量的估算可以用于时间复杂度的估算:

    “O的化简”:

    O(5) = O(1)

    O(2n+1) = O(2n) = O(n)

    O(n2+1) = O(n2)

    O(3n3+1) = O(3n3) = O(n3)

    III 算法的空间复杂度

    同样算法的空间复杂度也可以采用大O表示法。

  • 相关阅读:
    试试主题显示
    四则运算
    实验四 决策树算法及应用
    实验三 朴素贝叶斯算法及应用
    实验二 K-近邻算法及应用
    实验一 感知器及其应用
    实验三 面向对象分析与设计
    实验二 结构化分析与设计
    实验一 软件开发文档与工具的安装与使用
    举例分析流程图与活动图的区别与联系
  • 原文地址:https://www.cnblogs.com/wan0807/p/4898339.html
Copyright © 2011-2022 走看看