Python算法笔记(1)-时间复杂度、空间复杂度

Python算法笔记(1)-时间复杂度在这里插入图片描述

1.时间复杂度

时间复杂度是一个描述算法的运行时间的一个函数,它描述了算法的运行时间和输入数据的规模之间的关系,时间复杂度的表示方法用O表示,时间复杂度也用来考察输入值无限趋近无穷时的情况。

一:常量阶 O(1)

当执行次数为n时表示常量阶


def person(n):
    print("有%d个人" % n)
if __name__ == '__main__':
    person(3)

二:对数阶 O(logn)

当执行5logn次数是对数计算时


def person(n):
    while n>1:
        print("有%d个人" % n)
        print("他们都走了")
        n /= 2
if __name__ == '__main__':
    person(10)

在这里插入图片描述

三:线性阶 O(n)

3n次计算时是线性


def person(n):
    for i in range(n):
        print("有%d个人" % n)
        print("他们都走了")
if __name__ == '__main__':
    person(2)

四:线性对数阶 O(nlogn)


def person(n):
        while n > 1:
            print("有%d个人" % n)
            print("他们都走了")
            n*(n/2)

if __name__ == '__main__':
    person(2)

五:n方阶 O(nⁿ)

def person(n):
        for i in range(1,n):
            print("有%d个人" % n)
            print("他们都走了")
            NP = n**n
            print("n方阶是%d" %NP)

if __name__ == '__main__':
    person(2)

六:指数阶 O(2ⁿ)

def person(n):
        for i in range(1,n):
            print("有%d个人" % n)
            print("他们都走了")
            NP = 2**n
            print("n指数阶是%d" %NP)

if __name__ == '__main__':
    person(3)

七:阶乘阶 O(n!)


def person(n):
        res = 1
        for i in range(1,n+1):
            res *=i
            print("n阶乘阶是%d" %res)

if __name__ == '__main__':
    person(3)
    


当满足公式下的运行下,当n的增加时,运行效率在指数阶和阶乘阶的运行效率会变得非常低,所以需要合理选择一个计算方式,而运行速度来看:常量阶<对数阶<线性阶<n方阶

2.空间复杂度

空间复杂度是算法在运行时间复杂度算法时所占用的空间大小的度量,一般用S(n)表示。

一:常量空间

没有特殊标记O(n),跟输入规模没有直接的关系。

def ex(n):
	i = 3

二:线性空间

O(n),集合大小和输入规模n成正比

def ex(n):
	ar = [[0]*n]

三:二维空间

当算法分配一个空间是二维列表集合时,长度与宽度输入规模成正比,O(n2次方)

def ex(n):
	ar = [[0]*n]*n

四:递归空间

当计算机运行程序时会调用相应的内存来存储,也就有了出栈和入栈的行为,当函数返回时,信息就会从栈中出来

def ex(n):
	if n>>0:
		ar(n-1)

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

轻烟飘荡

我想吃甜筒

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值