python列表去重复后按照顺序_从包含不可共元素的Python列表中删除重复元素,同时保留顺序?...

from operator import itemgetter

from itertools import groupby, imap

def unique_justseen(iterable, key=None):

"List unique elements, preserving order. Remember only the element just seen."

# unique_justseen('AAAABBBCCDAABBB') --> A B C D A B

# unique_justseen('ABBCcAD', str.lower) --> A B C A D

return imap(next, imap(itemgetter(1), groupby(iterable, key)))如果您只能假定可订购元素,则此处使用bisect模块进行变体。给定具有r个唯一值的n个输入,其搜索步骤花费O(n log r)。如果找到新的唯一值,则将其插入到查看列表中,成本为O(r * r)。

from bisect import bisect_left, insort

def dedup(seq):

'Remove duplicates. Preserve order first seen. Assume orderable, but not hashable elements'

result = []

seen = []

for x in seq:

i = bisect_left(seen, x)

if i == len(seen) or seen[i] != x:

seen.insert(i, x)

result.append(x)

return result

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值