怎样进行算法的复杂度分析?

复杂度分析是估算算法执行效率的方法,公式O(f(n))表示算法的复杂度,此方法即为大O复杂度表示法O(f(n))中n表示数据规模,f(n)表示运行算法所需要执行的指令数。

大O复杂度表示法

下面的代码非常简单,求 1,2,3…n 的累加和,我们要做的是估算它的执行效率。

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + i return sum_

假设每行代码执行的时间都一样为t,执行第2行代码需要时间t,第3,4行代码运行了n遍,需要的时间为2n*t,这段代码总执行时间为(2n+1)* t

结论:代码执行的总时间T(n)与每行代码的执行次数成正比

看下面的代码,估算该段代码的执行时间:

def calc(n): sum_ = 0 for i in range(n): for j in range(n): sum_ = sum_ + i*j return sum_

同样假设每行代码执行的时间都一样为t:执行第2行代码需要时间t,第3行代码运行了n遍,需要时间为n*t,第4、5行代码运行了n2次,需要时间为2n2 * t,执行所有代码的总时间为 (2n2 + n + 1)* t。

结论:代码执行的总时间T(n)与每行代码的执行次数成正比。

用O(f(n))来表示算法复杂度:

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + i return sum_def calc(n): sum_ = 0 for i in range(n): for j in range(n): sum_ = sum_ + i*j return sum_

T(n) = O(f(n)) , O表示代码的执行时间T(n) 与 f(n)表达式成比例。

大O复杂度表示法:上面例子中的T(n) = O(2n+1), 另一个 T(n) = O(2n² + n + 1)。大O时间复杂度并不表示代码真正的执行时间,而是表示代码执行时间随数据规模增长的变化趋势,也叫作渐进时间复杂度(asymptotic time complexity),简称时间复杂度。

当数据量特别大, 也就是n的取值很大的时候,大O表示法中低阶、常量、系数三部分并不会左右增长趋势,可以忽略。

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + i return sum_def calc(n): sum_ = 0 for i in range(n): for j in range(n): sum_ = sum_ + i*j return sum_

上面例子中的T(n) = O(2n+1), 另一个 T(n) = O(2n² + n + 1),用大O表示法表示上面两段代码的时间复杂度,可以记为O(n),O(n²)。

算法A: O(n) 执行指令,10000*n

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + I “”” 此处省略n行… … “”” return sum_

算法B: O(n²) 执行指令数,10*n2

对比上面两个算法,当 n = 10, n=100 时, 算法B执行的速度更快,n = 1000 时两者速度相当

n = 104 , n = 105, n = 106 ,算法A执行的速度更快的

随着数据规模的进一步增大, 这个差距会越来越大

时间复杂度分析

如何分析一段代码的时间复杂度?

在分析一个算法、一段代码的时间复杂度时,只关注循环执行次数最多的那一段代码就可以了。

def calc(n): sum_ = 0 for i in range(n): for j in range(n): sum_ = sum_ + i*j return sum_

上面的代码中,我们只需要关注内层for循环的时间复杂度就可以了,内层for循环的两行代码被执行了n2次,所以总的时间复杂度就是O(n²)

总复杂度等于量级最大的那段代码的复杂度

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + i sum_1 = 0 for i in range(1,n+1): for j in range(n): sum_1 = sum_1 + i*j return sum_+sum_1

上面的代码分为两部分,分别是求 sum_、sum_1,计算sum_部分的代码段时间复杂度O(n),计算sum_1部分的代码段时间复杂度为O(n²) ,总的时间复杂度由复杂度最大的部分决定, 所以上面代码复杂度为O(n²)。

嵌套代码的复杂度等于嵌套内外代码复杂度的乘积

def fn(n): sum_ = 0 for i in range(n+1): sum_ = sum_ + i return sum_ def calc(n): sum_ = 0 for i in range(n+1): sum_ = sum_ + fn(i) return sum_

上面的代码中第二个函数调用了第一个函数, 如果把fn函数调用当作一个普通操作, 那么第二个函数的时间复杂度为O(n) Fn函数的时间复杂度为O(n),那么函数整体的时间复杂度为O(n*n) = O(n²)。

当两段代码的数据规模不同时,不能省略复杂度低的部分

def calc(n): sum_ = 0 for i in range(1,n+1): sum_ = sum_ + i sum_1 = 0 for i in range(1,m+1): for j in range(m): sum_1 = sum_1 + i*j return sum_+sum_1

上面的代码分为两部分,分别是求 sum_、sum_1,计算sum_部分的代码段时间复杂度O(n),计算sum_1部分的代码段时间复杂度为O(m2) ,总的时间复杂度由复杂度最大的部分决定, 所以上面代码复杂度为O(m²+n)

免责声明:文章内容来自互联网,本站仅作为分享,不对其真实性负责,如有侵权等情况,请与本站联系删除。
转载请注明出处:怎样进行算法的复杂度分析? https://www.dachanpin.com/a/cyfx/11021.html

(0)
上一篇 2023-05-12 02:42:54
苹果2024将推出无接口设计的iPhone?
下一篇 2023-05-12 02:43:59

相关推荐

  • 绝地求生刺激战场3Dtouch如何设置 3Dtouch设置技巧介绍

      A5创业项目春季招商 好项目招代理无忧   绝地求生刺激战场中的3Dtouch可以帮助玩家进行射击,对小伙伴们的枪法有非常大的提升,那么3Dtouch如何设置呢?下面小编为大家带来刺激战场3Dtouch的设置攻略详解。   绝地求生刺激战场3Dtouch怎么设置?   手机设置里把3d的按压强度调成高,绝地求生刺激战场的灵敏度要调低,不然容易走火。   …

    创业分享 2023-05-19
    151
  • 普安补者村两青年返乡创业带领村民奔富路

    “让乡亲挣得跟外面一样多” “家乡的人们,大多数土里刨食,填饱肚子都很辛苦,没地方就业如何致富奔小康呀?” “看到老家的人干活日晒雨淋,于是当我出门打工、走进工厂时,就想着有一天回来创业,让乡亲在家也能挣钱,挣得跟在外面一样多的钱。” “刚开始时主要生产一些民族服饰,销量也并不大。”黄园红说,直到2016年,着手开发了手袋,因为是外贸单,销量才慢慢大起来,工…

    创业分享 2023-05-19
    103
  • 吉林丰满:20名创业者提升网创能力

    为提升创业者网络创业能力,吉林市丰满区于7月16日在吉林市筑巢职业培训学校举办首期网络创业培训班,全区20名创业者参加了此次培训,此次培训培训学期为7天,邀请专业讲师采取翻转课堂、学习互助小组等多元化培训手段,依托教学辅助平台或互联网平台,对创业者进行互联网渠道创业的专业化指导和系统化训练,帮助创业者建立互联网创业思维,了解网络创业原理和创业流程,熟悉网络创…

    创业分享 2023-06-16
    215
  • 他们在创新创业的路上努力奔跑

    目前,户外宝已经更新到了第二代,完善了很多之前的不足,刘鸣这个“点子王”的角色可是发挥了很大的作用。户外宝第一代时,只能烤肉串等能用烤针串起来的食物,可烧烤时,很多人都喜欢吃烤海鲜、烤蔬菜等,刘鸣就想,要是在烤筒上能加一个烤盘就更完美了。当他把这个主意跟老师和团队同学说了之后,大家都很赞成并且马上研制出来了。 据黑龙江技师学院单清亮老师说,他平时经常在家做饭…

    2023-05-15
    127
  • 京东云创新空间(常州)启动 助力江苏数字经济产业创新发展

    5月23日,江苏数字经济产业创新大会在常州维景国际大酒店举行。此次大会由江苏省经信委指导,常州市天宁区人民政府、京东云、中国产业互联网发展联盟携手举办,旨在推进以云计算、大数据、人工智能为基础的数字经济的创新发展。 常州市人大常委会副主任李小平,工业和信息化部信息化和软件服务业司信息服务业处调研员杨志锋,工信部软件与集成电路促进中心科技发展处处长、中国产业互…

    2023-05-17
    197

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:362039258@qq.com

工作时间:周一至周五,9:30-16:30,节假日休息