Alen_Walker 2019-06-09 20:12 采纳率: 100%
浏览 1597
已采纳

python中关键字in对列表时的判断逻辑是怎样的?

我想知道python中使用if key in list 的时候,是怎么判断key有没有在列表中的,比如有没有遍历list?

问这个问题的原因是因为我纠结于下面这代码的时间复杂度是多少:

    for i in list1:
        if j in list2:

望大佬指点,感谢!

  • 写回答

3条回答 默认 最新

  • 观点小号 2019-06-12 16:12
    关注

    O(n^2)if ...in... 做遍历了
    如果觉得复杂度高的话可以考虑改用字典,或集合。
    python中list对象的存储结构采用的是线性表,因此其查询复杂度为O(n),而dict对象的存储结构采用的是散列表(hash表),其在最优情况下查询复杂度为O(1)。

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

悬赏问题

  • ¥15 c语言怎么用printf(“\b \b”)与getch()实现黑框里写入与删除?
  • ¥20 怎么用dlib库的算法识别小麦病虫害
  • ¥15 华为ensp模拟器中S5700交换机在配置过程中老是反复重启
  • ¥15 java写代码遇到问题,求帮助
  • ¥15 uniapp uview http 如何实现统一的请求异常信息提示?
  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?