热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

python代码优化时间_优化执行时间以检查单词的字符是否在列表python中

我修改了你的功能chars_array作为参数,进行了一些速度测试。defversion1(word,chars_array):chars[xforxinword]count0fo

我修改了你的功能

chars_array

作为参数,进行了一些速度测试。

def version1(word, chars_array):

chars =[x for x in word]

count = 0

for c in chars:

if not c in chars_array:

count+=1

return count

def version2(word):

return sum([1 for c in [x for x in word] if not c in chars_array])

我还想测试一个没有中间列表结构和@tomothy32的函数的修改版本

solution

char_array

通过):

def version1a(word, chars_array):

# remove intermediate list construction from word

count = 0

for c in word:

if not c in chars_array:

count+=1

return count

def version3(word, chars_array):

return len(word.translate(None, ''.join(chars_array)))

设置定时测试:

# first make some random words

import string

import numpy as np

max_word_len = 10

N = 10000

test_words = [

"".join(

np.random.choice(

list(string.ascii_lowercase),

np.random.randint(1, max_word_len)

)

)

for _ in range(N)

]

定时结果:

chars_array = ['a','b','c']

%%timeit

[version1(word, chars_array) for word in test_words]

#100 loops, best of 3: 11.2 ms per loop

%%timeit

[version1a(word, chars_array) for word in test_words]

#100 loops, best of 3: 8.01 ms per loop

%%timeit

[version2(word, chars_array) for word in test_words]

#100 loops, best of 3: 13.2 ms per loop

%%timeit

[version3(word, chars_array) for word in test_words]

#100 loops, best of 3: 5.29 ms per loop

如此清晰

version3()

使用

str.translate

是这里最快的。但如果我们把

查尔阵

在函数之外。

def version3a(word, chars_array):

return len(word.translate(None, chars_array))

重复正时测试:

chars_array = "".join(chars_array)

%%timeit

[version1(word, chars_array) for word in test_words]

#100 loops, best of 3: 10.1 ms per loop

%%timeit

[version1a(word, chars_array) for word in test_words]

#100 loops, best of 3: 6.61 ms per loop

%%timeit

[version2(word, chars_array) for word in test_words]

#100 loops, best of 3: 12 ms per loop

%%timeit

[version3(word, chars_array) for word in test_words]

#100 loops, best of 3: 12 ms per loop

%%timeit

[version3a(word, chars_array) for word in test_words]

#100 loops, best of 3: 3.87 ms per loop



推荐阅读
  • Python使用Pillow包生成验证码图片的方法
    本文介绍了使用Python中的Pillow包生成验证码图片的方法。通过随机生成数字和符号,并添加干扰象素,生成一幅验证码图片。需要配置好Python环境,并安装Pillow库。代码实现包括导入Pillow包和随机模块,定义随机生成字母、数字和字体颜色的函数。 ... [详细]
  • 电话号码的字母组合解题思路和代码示例
    本文介绍了力扣题目《电话号码的字母组合》的解题思路和代码示例。通过使用哈希表和递归求解的方法,可以将给定的电话号码转换为对应的字母组合。详细的解题思路和代码示例可以帮助读者更好地理解和实现该题目。 ... [详细]
  • YOLOv7基于自己的数据集从零构建模型完整训练、推理计算超详细教程
    本文介绍了关于人工智能、神经网络和深度学习的知识点,并提供了YOLOv7基于自己的数据集从零构建模型完整训练、推理计算的详细教程。文章还提到了郑州最低生活保障的话题。对于从事目标检测任务的人来说,YOLO是一个熟悉的模型。文章还提到了yolov4和yolov6的相关内容,以及选择模型的优化思路。 ... [详细]
  • 本文介绍了解决Netty拆包粘包问题的一种方法——使用特殊结束符。在通讯过程中,客户端和服务器协商定义一个特殊的分隔符号,只要没有发送分隔符号,就代表一条数据没有结束。文章还提供了服务端的示例代码。 ... [详细]
  • 本文介绍了一个Java猜拳小游戏的代码,通过使用Scanner类获取用户输入的拳的数字,并随机生成计算机的拳,然后判断胜负。该游戏可以选择剪刀、石头、布三种拳,通过比较两者的拳来决定胜负。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • Java容器中的compareto方法排序原理解析
    本文从源码解析Java容器中的compareto方法的排序原理,讲解了在使用数组存储数据时的限制以及存储效率的问题。同时提到了Redis的五大数据结构和list、set等知识点,回忆了作者大学时代的Java学习经历。文章以作者做的思维导图作为目录,展示了整个讲解过程。 ... [详细]
  • Python正则表达式学习记录及常用方法
    本文记录了学习Python正则表达式的过程,介绍了re模块的常用方法re.search,并解释了rawstring的作用。正则表达式是一种方便检查字符串匹配模式的工具,通过本文的学习可以掌握Python中使用正则表达式的基本方法。 ... [详细]
  • Python瓦片图下载、合并、绘图、标记的代码示例
    本文提供了Python瓦片图下载、合并、绘图、标记的代码示例,包括下载代码、多线程下载、图像处理等功能。通过参考geoserver,使用PIL、cv2、numpy、gdal、osr等库实现了瓦片图的下载、合并、绘图和标记功能。代码示例详细介绍了各个功能的实现方法,供读者参考使用。 ... [详细]
  • 基于dlib的人脸68特征点提取(眨眼张嘴检测)python版本
    文章目录引言开发环境和库流程设计张嘴和闭眼的检测引言(1)利用Dlib官方训练好的模型“shape_predictor_68_face_landmarks.dat”进行68个点标定 ... [详细]
  • 本文介绍了在iOS开发中使用UITextField实现字符限制的方法,包括利用代理方法和使用BNTextField-Limit库的实现策略。通过这些方法,开发者可以方便地限制UITextField的字符个数和输入规则。 ... [详细]
  • EPPlus绘制刻度线的方法及示例代码
    本文介绍了使用EPPlus绘制刻度线的方法,并提供了示例代码。通过ExcelPackage类和List对象,可以实现在Excel中绘制刻度线的功能。具体的方法和示例代码在文章中进行了详细的介绍和演示。 ... [详细]
  • 十大经典排序算法动图演示+Python实现
    本文介绍了十大经典排序算法的原理、演示和Python实现。排序算法分为内部排序和外部排序,常见的内部排序算法有插入排序、希尔排序、选择排序、冒泡排序、归并排序、快速排序、堆排序、基数排序等。文章还解释了时间复杂度和稳定性的概念,并提供了相关的名词解释。 ... [详细]
  • 开源Keras Faster RCNN模型介绍及代码结构解析
    本文介绍了开源Keras Faster RCNN模型的环境需求和代码结构,包括FasterRCNN源码解析、RPN与classifier定义、data_generators.py文件的功能以及损失计算。同时提供了该模型的开源地址和安装所需的库。 ... [详细]
  • 超级简单加解密工具的方案和功能
    本文介绍了一个超级简单的加解密工具的方案和功能。该工具可以读取文件头,并根据特定长度进行加密,加密后将加密部分写入源文件。同时,该工具也支持解密操作。加密和解密过程是可逆的。本文还提到了一些相关的功能和使用方法,并给出了Python代码示例。 ... [详细]
author-avatar
爱蜜儿小秋秋
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有