前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >python数据结构与算法(3)

python数据结构与算法(3)

作者头像
py3study
发布2020-01-06 16:55:37
2750
发布2020-01-06 16:55:37
举报
文章被收录于专栏:python3python3

Python内置类型性能分析 timeit模块 timeit模块可以⽤来测试⼀⼩段Python代码的执⾏速度。 class timeit.Timer(stmt='pass', setup='pass', timer=<timer function>) Timer是测量⼩段代码执⾏速度的类。 stmt参数是要测试的代码语句(statment); setup参数是运⾏代码时需要的设置; timer参数是⼀个定时器函数,与平台有关。 timeit.Timer.timeit(number=1000000) Timer类中测试语句执⾏速度的对象⽅法。number参数是测试代码时的测试 次数,默认为1000000次。⽅法返回执⾏代码的平均耗时,⼀个float类型的 秒数。 list的操作测试

代码语言:javascript
复制
def t1():           l   =   []          for i   in  range(1000):                        l   =   l   +   [i] def t2():           l   =   []          for i   in  range(1000):                        l.append(i) def t3():
代码语言:javascript
复制
  l   =   [i  for i   in  range(1000)] def    t4():           l   =   list(range(1000))
from    timeit  import  Timer
timer1  =   Timer("t1()",   "from   __main__    import  t1") print("concat  ",timer1.timeit(number=1000),   "seconds") timer2   =   Timer("t2()",   "from   __main__    import  t2") print("append  ",timer2.timeit(number=1000),   "seconds") timer3   =   Timer("t3()",   "from   __main__    import  t3") print("comprehension   ",timer3.timeit(number=1000),   "seconds") timer4   =   Timer("t4()",   "from   __main__    import  t4") print("list    range   ",timer4.timeit(number=1000),   "seconds")
#   ('concat    ',  1.7890608310699463, 'seconds') #    ('append    ',  0.13796091079711914,    'seconds') #    ('comprehension ',  0.05671119689941406,    'seconds') #    ('list  range   ',  0.014147043228149414,   'seconds')

pop操作测试

代码语言:javascript
复制
x   =   range(2000000) pop_zero =   Timer("x.pop(0)","from  __main__    import  x") print("pop_zero ",pop_zero.timeit(number=1000), "seconds") x    =   range(2000000) pop_end  =   Timer("x.pop()","from   __main__    import  x") print("pop_end  ",pop_end.timeit(number=1000),  "seconds")
#   ('pop_zero  ',  1.9101738929748535, 'seconds') #    ('pop_end   ',  0.00023603439331054688, 'seconds')

测试pop操作:从结果可以看出,pop最后⼀个元素的效率远远⾼于pop第⼀ 个元素

可以⾃⾏尝试下list的append(value)和insert(0,value),即⼀个后⾯插⼊ 和⼀个前⾯插⼊???

list内置操作的时间复杂度

python数据结构与算法(3)
python数据结构与算法(3)

dict内置操作的时间复杂度

python数据结构与算法(3)
python数据结构与算法(3)
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2019-09-22 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档