[首页]
[文章]
[教程]
首页
Web开发
Windows开发
编程语言
数据库技术
移动平台
系统服务
微信
设计
布布扣
其他
数据分析
首页
>
其他
> 详细
大 Θ记号、大 Ω记号、空间复杂度、时间复杂度
时间:
2016-08-11 00:38:53
阅读:
422
评论:
0
收藏:
0
[点我收藏+]
最坏情况:以大O记号形式表示的时间复杂度,给出了一个算法的最坏情况,即--对于规模为n的任意输入,算法的运行时间都不会超过O(f(n))
最好情况 :大 Ω记号-->如果存在正的常数c和函数g(n),对任意n>>2,有T(n) > c * g(n),即认为:在n足够 大后,g(n)给出了T(n)的一个下界,记为:
T(n) =Ω (g(n))
大 Θ记号-->存在正的常数c1和c2,以及函数h(n),对任意n>>2,有 c1*h(n) < T(n) < c2 * h(n),即认为:在n足够大后,h(n)给出了T(n)的一个确界,记为:
T(n) =Θ (g(n))
空间复杂度:
空间复杂度通常不计入原始输入本身所占用的空间
由于:
任意算法的任何一次运行过程中所消耗的存储空间,都不会多于其间所执行基本操作的累积次数;
每次基本操作所涉及的存储空间都不会超过常数规模;
即使每次基本操作所占用或访问的存储空间都是新开辟的,整个算法所需的空间总量,也不过与基本操作的次数同阶;
故:时间复杂度本身就是空间复杂度的一个天然上界
当然,由时间复杂度确定的平凡上界不能令人满意,则可更为精细地考察不同算法的空间
复杂度分析:
O(1):常数时间复杂度算法
不含转向(循环调用、递归等)必顺序执行,即使O(1),反之则不一定
O(logn):对数时间复杂度
常底数无所谓:
常数次幂无所谓:
考虑问题:对于任意非负整数,统计其二进制中数位1的总是
一般方法:
int countOnes (unsinged int n) {
int ones = 0;
while (n > 0) {
if (1 & n) {
ones += 1;
}
n = n >> 1;
}
return ones;
}
由右移位运算性质,n缩减至0,需要
次运算,即该算法的时间复杂度为:
对数多项式复杂度:凡运行时间可以表示和度量为
(其中c>0),则 称为“对数多项式时间复杂度的算法”
大 Θ记号、大 Ω记号、空间复杂度、时间复杂度
原文:http://www.cnblogs.com/joh-n-zhang/p/5759250.html
踩
(
0
)
赞
(
0
)
举报
评论
一句话评论(
0
)
登录后才能评论!
分享档案
更多>
2021年09月23日 (328)
2021年09月24日 (313)
2021年09月17日 (191)
2021年09月15日 (369)
2021年09月16日 (411)
2021年09月13日 (439)
2021年09月11日 (398)
2021年09月12日 (393)
2021年09月10日 (160)
2021年09月08日 (222)
最新文章
更多>
2021/09/28 scripts
2022-05-27
vue自定义全局指令v-emoji限制input输入表情和特殊字符
2022-05-27
9.26学习总结
2022-05-27
vim操作
2022-05-27
深入理解计算机基础 第三章
2022-05-27
C++ string 作为形参与引用传递(转)
2022-05-27
python 加解密
2022-05-27
JavaScript-对象数组里根据id获取name,对象可能有children属性
2022-05-27
SQL语句——保持现有内容在后面增加内容
2022-05-27
virsh命令文档
2022-05-27
教程昨日排行
更多>
1.
list.reverse()
2.
Django Admin 管理工具
3.
AppML 案例模型
4.
HTML 标签列表(功能排序)
5.
HTML 颜色名
6.
HTML 语言代码
7.
jQuery 事件
8.
jEasyUI 创建分割按钮
9.
jEasyUI 创建复杂布局
10.
jEasyUI 创建简单窗口
友情链接
汇智网
PHP教程
插件网
关于我们
-
联系我们
-
留言反馈
- 联系我们:wmxa8@hotmail.com
© 2014
bubuko.com
版权所有
打开技术之扣,分享程序人生!