Python 去除序列s中的重复元素

1.在可hash的情况下使用set,时间复杂度为 O(n)
return list(set(s))
2.不可hash,但支持比较使用sort,时间复杂度为 O(nlogn)
t=list(s) try:     t.sort() except TypeError:     del t else:     return [x for i,x in enumerate(t) if not i or t[i]!=t[i-1]]
3.前两者都不能的情况下利用in判断,时间复杂度为 O(n**2)
u=[] for x in s:     if x not in u:          u.append(x) 

return u

enumerate()函数使用说明:

enumerate( sequence [start=0 ])

Return an enumerate object. sequence must be a sequence, an iterator, or 

some other object which supports iteration. The next() method of the

iterator returned by enumerate() returns a tuple containing a count 

(from start which defaults to 0) and the values obtained from iterating oversequence:

>>> seasons = ['Spring', 'Summer', 'Fall', 'Winter']

>>> list(enumerate(seasons)) [(0, 'Spring'), (1, 'Summer'), (2, 'Fall'), (3, 'Winter')] 

>>> list(enumerate(seasons, start=1)) [(1, 'Spring'), (2, 'Summer'), (3, 'Fall'), (4, 'Winter')

转载于:https://my.oschina.net/taisha/blog/36479

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值