如何解决更新python列表的最简洁方法?
假设我有一个包含 100 个从 0 到 99 的唯一整数的列表。现在我有 10,000 个从 0 到 199 的新整数(当然还有重复项)。我想将每个新整数附加到列表中并不断更新列表。只要列表中已经存在相同的整数,就应该删除旧的整数。更新后的列表仍应是所有唯一整数的列表。
我的第一直觉是使用 set().add()
,但 set 是无序的,因此不能用于更新序列。我设法编写了以下代码,效果很好。将 10,000 个新整数更新为 100 个 unqiue 整数的列表需要 47 毫秒。
import random
from time import time
random.seed(99)
newlen = 10000
lst = list(range(100))
random.shuffle(lst)
newlst = [random.randrange(200) for _ in range(newlen)]
t0 = time()
for new in newlst:
idx = next((i for i,n in enumerate(lst) if n == new),None)
if idx is not None:
lst.pop(idx)
lst.append(new)
print(time()-t0)
输出:
0.04717659950256348
但是,我觉得应该有更快更简洁的方法来更新 python 列表。有什么建议吗?
解决方法
看看这个例子 -
mylist.sort() # To sort a list in a order
set(mylist) # To get duplicate values in correct order
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。