博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
数据结构与算法(二)—— 大O表示法
阅读量:6167 次
发布时间:2019-06-21

本文共 689 字,大约阅读时间需要 2 分钟。

算法的定义

  • 算法是对某个问题求解步骤的描述,是指令的有限序列。
  • 算法与数据结构紧密联系,在设计算法前要确定相应的数据结构。
  • 最后,算法与数据的规模也息息相关,当数据规模越大是越能提现各种算法的性能。

算法性能的分析和度量

时间复杂度

时间复杂度:

  • 由于算法的执行时间取决于算法的结构和原操作(最影响算法性能的代码实现),所以一个算法执行时间的计算是很艰难的。因此,通过计数算法原操作的重复执行的次数作为算法的时间度量,引入“渐进时间复杂度”估计算法的执行时间来分析算法。而算法的表示方式则用大O表示法。

大O表示法的定义:如果存在两个正常数cn0,使得对所有的n,n >= n0,有T(n)<= cF(n)。则有 T(n) = O(F(n))

  • 通过比较T(n)和F(n)的相对增长率来分析算法。例如:T(n)=1000*n,F(n)=n^2,当n>=1000(就是上面定义的n0)时,F(n)T(n)更快的增长率。大O表示法:1000*n=O(n^2)T(n) = O(n^2)
  • 我们可以这样理解T(n) = O(f(n)),T(n)以永远不快于F(n)的速度增长,F(n)是T(n)的一个上界。例如: 当T(n) = 2n^2,则可以T(n) = O(n^3)T(n) = O(n^2)T(n) = O(n^3),这些等式以不快于F(n)的定义来说都是成立的,但我们要选择一个尽可能接近的T(n) = O(n^2)

O表示法的计算

如果T1(n) = O(f(n)),T2(n) = O(g(n)),则有:

  1. T1(n) + T2(n) = max(O(f(n)) + O(g(n))),即T(n) = n^4 + n^2 + 3 = O(n^4)
  2. T1(n) * T2(n) = O(f(n) * g(n)),即T(n) = n^4 * n^2 + 3 = O(n^6)

注意:在计算大O表示时,低价项和常数项可以被忽略。

常见的大O表示法及代表的算法(从快到慢排列)

  • O(1)
  • O(log n),也叫对数时间,如二分查找算法。
  • O(n),也叫线性时间,如遍历n个规模的数查找。
  • O(n * log n),如快速排序算法
  • O(n^2),如选择排序、冒泡排序。
  • O(n!),一种非常慢的算法

空间复杂度

空间复杂度是一个操作或者一个程序从开始到结束所需的空间存储大小。 包括以下两部分:

  • 固定部分:主要包括程序代码、常量、简单变量、定长成分的结构变量所占的空间。
  • 可变部分:算法的规模大小影响操作所需的存储空间大小

转载地址:http://kluba.baihongyu.com/

你可能感兴趣的文章
多路归并排序之败者树
查看>>
java连接MySql数据库
查看>>
深入python的set和dict
查看>>
DEV实现日期时间效果
查看>>
java注解【转】
查看>>
centos 下安装g++
查看>>
下一步工作分配
查看>>
Response. AppendHeader使用大全及文件下载.net函数使用注意点(转载)
查看>>
centos64i386下apache 403没有权限访问。
查看>>
jquery用法大全
查看>>
PC-BSD 9.2 发布,基于 FreeBSD 9.2
查看>>
css斜线
查看>>
Windows phone 8 学习笔记(3) 通信
查看>>
Revit API找到风管穿过的墙(当前文档和链接文档)
查看>>
Scroll Depth – 衡量页面滚动的 Google 分析插件
查看>>
Windows 8.1 应用再出发 - 视图状态的更新
查看>>
自己制作交叉编译工具链
查看>>
Qt Style Sheet实践(四):行文本编辑框QLineEdit及自动补全
查看>>
[物理学与PDEs]第3章习题1 只有一个非零分量的磁场
查看>>
onInterceptTouchEvent和onTouchEvent调用时序
查看>>