您好, 欢迎来到 !    登录 | 注册 | | 设为首页 | 收藏本站

根据每个列表的第一个元素从列表中删除项目

根据每个列表的第一个元素从列表中删除项目

反向删除a,就地修改

for i in reversed(range(len(a))):
    if a[i][0] == 3:
        del a[i]

就地修改意味着这样做效率更高,因为它不会创建新列表(如列表理解那样)。

由于OP要求提供高效的解决方案,因此这里timeit比较了两个投票最高的答案。

设定 -

a = np.random.choice(4, (100000, 2)).tolist()

print(a[:5])
[[2, 1], [2, 2], [3, 2], [3, 3], [3, 1]]

清单理解-

%timeit [x for x in a if x[0] != b]
11.1 ms ± 685 µs per loop (mean ± std. dev. of 7 runs, 100 loops each)

反向删除-

%%timeit
for i in reversed(range(len(a))):
    if a[i][0] == 3:
        del a[i]

10.1 ms ± 146 µs per loop (mean ± std. dev. of 7 runs, 1 loop each)

它们确实很接近,但是 反向删除 性能提高了1UP,因为它不必像列表理解那样在内存中生成新列表。

其他 2022/1/1 18:27:38 有402人围观

撰写回答


你尚未登录,登录后可以

和开发者交流问题的细节

关注并接收问题和回答的更新提醒

参与内容的编辑和改进,让解决方法与时俱进

请先登录

推荐问题


联系我
置顶