python中列表in_在python中使用in运算符搜索列表时使用什么算法?

不能假定lists是按排序顺序(或任何顺序)进行的,因此二进制搜索将无法工作。也不能假定这些键是可散列的,因此与dict或{}不同的是,哈希表查找不能用于加速搜索

猜猜看,这是对每个元素从头到尾的直接检查。在

我将尝试挖掘相关的Python源代码。在

编辑:实现list.__contains__()运算符的Pythonlist.__contains__()函数在listobject.c中定义:393 static int

394 list_contains(PyListObject *a, PyObject *el)

395 {

396 Py_ssize_t i;

397 int cmp;

398

399 for (i = 0, cmp = 0 ; cmp == 0 && i < Py_SIZE(a); ++i)

400 cmp = PyObject_RichCompareBool(el, PyList_GET_ITEM(a, i),

401 Py_EQ);

402 return cmp;

403 }

它迭代列表中的每个元素,从第一个元素到最后一个元素(或直到找到匹配项为止)。在

编辑2:图变粗。如果Python检测到您正在测试一个常量list或{}中元素的成员身份,比如:

^{pr2}$

编辑3[@JohnMachin]:

在2.5-2.7和3.1-3.3中,常量列表被优化为常量元组。

常数集在3.3中优化为(常数)冻结集。在

另请参见@CoryCarson的答案。在

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值