数据结构和算法(代码执行时间测量模块timeit)

2024-02-23 13:32

本文主要是介绍数据结构和算法(代码执行时间测量模块timeit),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

考察python的执行效率,python在调用函数的时候,要考察其函数内部算法的效率,本文将利用python中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类型的秒数。

python列表类型不同操作的时间效率

python生成列表的常见形式有一下四种:

  1. 两个列表的相加
  2. 列表生成器
  3. 可迭代对象转化为列表
  4. 对空列表进行元素追加

对于以上四种形式,自定义四种函数实现

#对空列表进行元素追加
def test1():li = []for i in range(10000):li.append(i)
def test2():li = []for i in range(10000):li =li + [i]
def test3():li = [i for i in range(10000)]
def test4():li = list(range(10000))def test5():li = []for i in range(10000):li.extend([i])    
from timeit import Timertimer1 = Timer('test1()','from __main__ import test1')
print("append追加:",timer1.timeit(1000))timer2 = Timer('test2()','from __main__ import test2')
print("求和:",timer2.timeit(1000))timer3 = Timer('test3()','from __main__ import test3')
print("列表生成器:",timer3.timeit(1000))timer4 = Timer('test4()','from __main__ import test4')
print("可迭代对象转化:",timer4.timeit(1000))timer5 = Timer('test5()','from __main__ import test5')
print("extend:",timer5.timeit(1000))
结果

append追加: 0.6496986700076377
求和: 0.7470834940031637
列表生成器: 0.30637266401026864
可迭代对象转化: 0.14538886799709871
extend: 0.9688844589982182

元素追加(append和insert)
def t6():li = []for i in range(10000):li.append(i) #尾部添加def t7():li = []for i in range(10000):li.insert(0,i)#头部添加 
timer6 = Timer('t6()','from __main__ import t6')
print("append:",timer6.timeit(1000))timer7 = Timer('t7()','from __main__ import t7')
print("insert:",timer7.timeit(1000))
结果

append: 0.6802220060053514
insert: 28.873230566998245

结果来看尾部添加的效率明显优于头部添加,这与python的列表数据存储方式决定的,后续写数据结构时将对此进行解答

同理,pop删除元素方式,从队头删除的效率要远远低于从队尾删除元素的效率。

list内置函数的时间复杂度

OperationBig-O Efficiency
index x[]O(1)
index assignmentO(1)
append()O(1)
pop()O(1)
pop(i)O(n)
insertO(n)
del operatorO(n)
iterationO(n)
contains(in)O(n)
get slice[x:y]O(k)
del sliceO(n)
set sliceO(n+k)
reverseO(n)
concatenameO(k)
sortO(nlogn)
multiplyO(nk)

dict内置函数的时间复杂度

OperationBig-O Efficiency
copyO(n)
get itemO(1)
set itemO(1)
delete itemO(1)
iterationO(n)
contains(in)O(1)

这篇关于数据结构和算法(代码执行时间测量模块timeit)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/738802

相关文章

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g

多模块的springboot项目发布指定模块的脚本方式

《多模块的springboot项目发布指定模块的脚本方式》该文章主要介绍了如何在多模块的SpringBoot项目中发布指定模块的脚本,作者原先的脚本会清理并编译所有模块,导致发布时间过长,通过简化脚本... 目录多模块的springboot项目发布指定模块的脚本1、不计成本地全部发布2、指定模块发布总结多模

Python中构建终端应用界面利器Blessed模块的使用

《Python中构建终端应用界面利器Blessed模块的使用》Blessed库作为一个轻量级且功能强大的解决方案,开始在开发者中赢得口碑,今天,我们就一起来探索一下它是如何让终端UI开发变得轻松而高... 目录一、安装与配置:简单、快速、无障碍二、基本功能:从彩色文本到动态交互1. 显示基本内容2. 创建链

Node.js 中 http 模块的深度剖析与实战应用小结

《Node.js中http模块的深度剖析与实战应用小结》本文详细介绍了Node.js中的http模块,从创建HTTP服务器、处理请求与响应,到获取请求参数,每个环节都通过代码示例进行解析,旨在帮... 目录Node.js 中 http 模块的深度剖析与实战应用一、引言二、创建 HTTP 服务器:基石搭建(一

如何用Java结合经纬度位置计算目标点的日出日落时间详解

《如何用Java结合经纬度位置计算目标点的日出日落时间详解》这篇文章主详细讲解了如何基于目标点的经纬度计算日出日落时间,提供了在线API和Java库两种计算方法,并通过实际案例展示了其应用,需要的朋友... 目录前言一、应用示例1、天安门升旗时间2、湖南省日出日落信息二、Java日出日落计算1、在线API2

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

python中的与时间相关的模块应用场景分析

《python中的与时间相关的模块应用场景分析》本文介绍了Python中与时间相关的几个重要模块:`time`、`datetime`、`calendar`、`timeit`、`pytz`和`dateu... 目录1. time 模块2. datetime 模块3. calendar 模块4. timeit

Python模块导入的几种方法实现

《Python模块导入的几种方法实现》本文主要介绍了Python模块导入的几种方法实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学... 目录一、什么是模块?二、模块导入的基本方法1. 使用import整个模块2.使用from ... i

Java将时间戳转换为Date对象的方法小结

《Java将时间戳转换为Date对象的方法小结》在Java编程中,处理日期和时间是一个常见需求,特别是在处理网络通信或者数据库操作时,本文主要为大家整理了Java中将时间戳转换为Date对象的方法... 目录1. 理解时间戳2. Date 类的构造函数3. 转换示例4. 处理可能的异常5. 考虑时区问题6.