鱼C论坛

 找回密码
 立即注册
查看: 1958|回复: 3

[已解决]我可以理解运行时间的不同,但我无法理解结果不一样

[复制链接]
发表于 2023-3-20 20:48:57 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
链接:【I】添加一行代码,提高10000倍以上的执行效率
为什么结果(找到了几个匹配那个)不一样,隐藏的内容里没说
最佳答案
2023-3-20 20:53:51
因为他那个用了random随机呀,如果你每一次都用同一个随机种子结果就相同了
import random
import timeit

#############   这里指定随机种子
random.seed(1000)
#############

haystack = [random.randint(1, 10000000) for i in range(10000000)]
needles = [random.randint(1, 1000) for i in range(1000)]

# 请在此处添加一行代码,使得查找过程的执行效率提高 10000 倍以上。
haystack = set(haystack)

def find():
    found = 0
    for each in needles:
        if each in haystack:
            found += 1

    print(f"一共找到{found}个匹配。")

t = timeit.timeit("find()", setup="from __main__ import find", number=1)
print(f"查找过程一共消耗{t}秒。")

不自己设置随机种子的话,随机种子好像默认是用时间戳算出来的,不是同一时间运行的结果当然不一样呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2023-3-20 20:53:51 | 显示全部楼层    本楼为最佳答案   
因为他那个用了random随机呀,如果你每一次都用同一个随机种子结果就相同了
import random
import timeit

#############   这里指定随机种子
random.seed(1000)
#############

haystack = [random.randint(1, 10000000) for i in range(10000000)]
needles = [random.randint(1, 1000) for i in range(1000)]

# 请在此处添加一行代码,使得查找过程的执行效率提高 10000 倍以上。
haystack = set(haystack)

def find():
    found = 0
    for each in needles:
        if each in haystack:
            found += 1

    print(f"一共找到{found}个匹配。")

t = timeit.timeit("find()", setup="from __main__ import find", number=1)
print(f"查找过程一共消耗{t}秒。")

不自己设置随机种子的话,随机种子好像默认是用时间戳算出来的,不是同一时间运行的结果当然不一样呀
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2023-3-20 21:00:08 | 显示全部楼层
isdkz 发表于 2023-3-20 20:53
因为他那个用了random随机呀,如果你每一次都用同一个随机种子结果就相同了

已理解,这是我犯的低级错误
我还有一个问题:因为数据不一样,所以 in 的判断(不是判断方法)也会有影响吧
根据小甲鱼的说法,普通列表 in 是一个一个找的
那在[0, 1, 1, 1]找一的话找到第二个就立马返回;
那[0, 0, 0, 1]是不是运行就会慢一点?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-3-20 21:03:19 | 显示全部楼层
歌者文明清理员 发表于 2023-3-20 21:00
已理解,这是我犯的低级错误
我还有一个问题:因为数据不一样,所以 in 的判断(不是判断方法 ...

从头到尾查找的话目标元素越往后确实效率越低,所以 python 有一个库叫 bisect,可以用这个库的二分查找来提高效率
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-9-24 05:21

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表