鱼C论坛

 找回密码
 立即注册
查看: 2709|回复: 2

[已解决]numpy数据查找问题

[复制链接]
发表于 2022-9-29 08:34:56 | 显示全部楼层 |阅读模式
30鱼币
  1. a=np.array([[1,2,3,4],
  2.             [5,6,7,8],
  3.             [9,10,11,12]])

  4. b=np.array([[6,7],
  5.             [10,11]])
复制代码


a,b内的数据为随机的
用什么算法能最快的从a中查找到b
最佳答案
2022-9-29 08:34:57
本帖最后由 阿奇_o 于 2022-9-29 15:03 编辑

怎么才算最快呢?。。不知道是不是“最快”,仅供参考:
  1. stmt = """\
  2. a=np.array([[1,2,3,4],[5,6,7,8],[9,10,11,12]])
  3. b=np.array([[6,7],[10,11]])
  4. def isInA(a, b):
  5.     af, bf = a.flatten(), b.flatten()
  6.     #return sum(map(lambda _: _ in af, bf)) == len(bf)
  7.     return all(map(lambda _: _ in af, bf))

  8. isInA(a, b)
  9. """
  10. import timeit as t
  11. t.timeit(stmt, setup="import numpy as np", number=1000)
  12. 0.019886699999915436
复制代码


ps:如果改为 随机创建类似大小的a,b,大概要 0.04 秒   (当然还要看你的a,b具体是怎样的范围条件,以及硬件资源)

最佳答案

查看完整内容

怎么才算最快呢?。。不知道是不是“最快”,仅供参考: ps:如果改为 随机创建类似大小的a,b,大概要 0.04 秒 (当然还要看你的a,b具体是怎样的范围条件,以及硬件资源)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2022-9-29 08:34:57 | 显示全部楼层    本楼为最佳答案   
本帖最后由 阿奇_o 于 2022-9-29 15:03 编辑

怎么才算最快呢?。。不知道是不是“最快”,仅供参考:
  1. stmt = """\
  2. a=np.array([[1,2,3,4],[5,6,7,8],[9,10,11,12]])
  3. b=np.array([[6,7],[10,11]])
  4. def isInA(a, b):
  5.     af, bf = a.flatten(), b.flatten()
  6.     #return sum(map(lambda _: _ in af, bf)) == len(bf)
  7.     return all(map(lambda _: _ in af, bf))

  8. isInA(a, b)
  9. """
  10. import timeit as t
  11. t.timeit(stmt, setup="import numpy as np", number=1000)
  12. 0.019886699999915436
复制代码


ps:如果改为 随机创建类似大小的a,b,大概要 0.04 秒   (当然还要看你的a,b具体是怎样的范围条件,以及硬件资源)

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2022-9-29 19:35:05 | 显示全部楼层
阿奇_o 发表于 2022-9-29 14:21
怎么才算最快呢?。。不知道是不是“最快”,仅供参考:

我需要找到b在a中的位置
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-5-20 13:49

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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