Python影响嵌套循环结构执行速度的因素与优化思路

董付国老师Python系列教材(累计印刷超过200次)推荐与选用参考

开学第一课:一定不要这样问老师Python问题

3000道Python习题免费在线练习

“Python小屋”1300篇历史文章分类速查表

董付国老师Python教学PPT汇总与题库分享

==============

版权声明:由于公众号后台规则问题,本文暂时无法设置原创标记,但仍属原创内容,微信公众号“Python小屋”坚持只发原创技术文章。

=============

推荐教材:董付国著,《Python数据分析与数据可视化(微课版)》,ISBN:978-7-302-62420-2,清华大学出版社,2023年6月出版,2023年8月第2次印刷

配套资源:教学大纲、课件、源码、数据文件、34小时微课

7651cf00348872f4e2ca84ded0dd2000.jpeg

=============

问题描述:

在循环结构中,如果没有break语句的话,循环条件的测试次数比循环体的实际执行次数多1,最后一次测试不满足条件,循环结束。对于嵌套循环结构,在不影响结果的情况下,循环次数少的循环作为外循环时循环条件测试的总次数更少。这一点对for循环和while循环都适用。

Python扩展库memory_profiler中的修饰器函数profile()可以用来跟踪和收集程序执行过程中内存占用与释放情况,输出结果中的Occurrences列显示了每行代码的执行次数,可以用来验证上面的描述。

测试代码如下,可以自行补充代码修改func3()中while内外循环的次数观察运行结果的变化。

7841635be70f4223bd4130c83699365c.png

运行结果:

941759a1410c57af0a00f30fda2f3d80.png

在实际使用中,这对代码效率的影响并不大,一来很多情况中交换内外循环会影响功能,二来循环结构运行时间主要取决于循环体代码,循环条件测试次数的减少几乎可以忽略。并且,嵌套循环结构中内循环次数较多时解释器会进行优化。例如,

b7e358d4605c272efb7889303cdd0b6b.png

虽然第二段代码外循环次数小,循环条件测试的总次数少了很多,但并没有像预期的那样提高速度,反而比第一段代码还慢。

如果内循环次数很少的话,解释器可能不会额外进行优化,此时交换内外循环对效率影响比较明显。例如,

98c4efd71d645377b03de77c51ae9d1f.png

那么,如何提高循环结构的执行速度呢,下面介绍两种思路,一是尽量减少内循环中不必要的计算,能往外提的计算尽量往外提。例如,

0d34d921688146b93c20f7480f967f36.png

另一种方法是,如果能使用列表推导式改写的话就使用列表推导式,因为Python解释器在底层对列表推导式进行了大量优化。例如,

678cb7d983563cb39f269521bc267aa9.png

=================

温馨提示:

关注微信公众号“Python小屋”,在公众号后台发送消息“大事记”可以查看董付国老师与Python有关的重要事件;发送消息“教材”可以查看董付国老师出版的Python系列教材(已累计印刷超过200次)的适用专业详情;发送消息“历史文章”可以查看董付国老师推送的超过1300篇原创技术文章;发送消息“会议”可以查看近期董付国老师的培训安排;发送消息“微课”可以查看董付国老师免费分享的超过700节Python微课视频;发送消息“课件”可以查看董付国老师免费分享的Python教学资源;发送消息“小屋刷题”可以下载“Python小屋刷题神器”,免费练习3857道客观题和776道编程题,题库持续更新;发送消息“编程比赛”了解Python小屋编程大赛详情。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值