人工智能:怎样进行算法的复杂度分析?

复杂度分析是估算算法执行效率的方法,公式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/11019.html

(0)
上一篇 2023-05-12 02:42:28
下一篇 2023-05-12 02:43:34

相关推荐

  • 优秀毕业生挂7门究竟是怎么回事? 创业学院副院长说了什么引起网

    某高职院校创业学院副院长的一段讲话视频   中国小康网讯  每逢毕业季,在离校前一些学生会被推荐作为优秀毕业生。但最近一个大学生挂科7门,却仍被推荐省优秀毕业生的案例引发了诸多讨论。这始于某高职院校创业学院副院长的一段讲话视频,他的这一番话瞬间引发网络热议。在创业学院,创业好的学生是更好的学生?有网友表示不理解,“难道读了这么多年书只是为了创业?”…

    2023-05-16
    76
  • 技术人如何甄别靠谱的创业公司

    但是我想强调的是:并不是所有拿了B轮C轮的创业公司真的都是安全的。特别是在融资泡沫期运气好,拿了巨额融资的公司,很可能业务就是一塌糊涂的,根本没有前途可言。 能不能找到一家有前途的创业公司,这件事情有很大的运气成分。我有一位朋友,很早就是技术牛人,在阿里巴巴十八罗汉还在湖畔花园创业的时候,阿里邀请他加入创业,但是他没去,他选择出国,去了美国雅虎。如今我们笑称…

    创业分享 2023-05-20
    61
  • 阴阳师陆生皮肤碎片怎么获得 第二期陆生皮肤碎片一天可以获得几个

      碎片获取途径:(体验服)   同样需要碎片合成SSR式神奴良陆生,包括抽卡和副本两个获得方式,另外捐赠也可以得到碎片   2、2018年3月1日0:00-2018年3月6日23:59期间,完成每日任务可额外获得「雪下红梅」皮肤碎片。   式神获得:   1、2018年2月28日维护后-2018年3月6日23:59期间,逢魔之时探索4次后获得的宝箱奖励(3…

    创业分享 2023-05-19
    172
  • 荼兰网创始人张伯恩:创业就是捂住伤口,快速成长

    但当自己真正去做一件事的时候,困难就来了。因为所有的一切都是从零开始。从最初的办公室选址装修、团队建设、框架设计、网站搭建、制度制定等一系列的问题前期都需要你一个人解决,而且必须高效率的去解决。其实创业最大的收获就是教会了我,一定要去面对每一个问题,并一步一步去解决每一个问题。在刚开始的时候,为了在团队建设初期,能够先活下去,白天忙工作,晚上回去兼职在百度传…

    创业分享 2023-05-25
    90
  • 区块链如何降低投资创业公司的风险

    话虽如此,你可能还是要耐心等待,看看加密市场接下来会发生什么。最好是等到证交会完成他们的工作,然后再考虑投资于加密货币。 技术的扩散极大地提高了初创企业的普及率,并促进了它们所产生的产业的多样性。然而,随着创业公司和企业家数量的不断扩大,投资者也会进行更复杂、更耗时的分析。谨慎对待投资机会需要对某个特定行业或市场有敏锐的认识、经验和洞察力。 投资者正在寻找合…

    2023-05-13
    91

发表回复

登录后才能评论

联系我们

在线咨询: QQ交谈

邮件:362039258@qq.com

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