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表示法。

  • 相关阅读:
    Android 摇一摇之双甩功能
    Android 上千张图片的列表滑动加载
    Android 新手引导
    Android 自定义列表指示器
    Mininet的安装与卸载
    ubuntu装机必备
    linux系统中利用vagrant创建虚拟开发环境
    Ubuntu右键添加:open in terminal
    ryu启动问题总结
    新建WORD文档打开会出现转换文件对话框3步解决办法
  • 原文地址:https://www.cnblogs.com/wan0807/p/4898339.html
Copyright © 2011-2022 走看看