首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用O(nlogn)的时间复杂度计算列表中发生的次数

用O(nlogn)的时间复杂度计算列表中发生的次数
EN

Stack Overflow用户
提问于 2013-12-15 06:21:00
回答 2查看 4.6K关注 0票数 7

到目前为止,这就是我所拥有的:

代码语言:javascript
复制
alist=[1,1,1,2,2,3,4,2,2,3,2,2,1]
def icount(alist):
    adic={}
    for i in alist:
        adic[i]=alist.count(i)
    return adic

print(icount(alist))

我做了一些研究,发现list.count()的时间复杂度是O(n),因此,这段代码将是O(n^2)。

有没有办法把这个减少到O(nlogn)?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2013-12-15 06:23:10

您可以像这样使用Counter

代码语言:javascript
复制
from collections import Counter
alist=[1,1,1,2,2,3,4,2,2,3,2,2,1]
print Counter(alist)

如果你想使用你的解决方案,你可以这样改进它

代码语言:javascript
复制
def icount(alist):
    adic = {}
    for i in alist:
        adic[i] = adic.get(i, 0) + 1
    return adic

更好的是,您可以像这样使用defaultdict

代码语言:javascript
复制
from collections import defaultdict
adic = defaultdict(int)
for i in alist:
    adic[i] += 1
return adic

另外,您可能需要查看不同Python对象( 这里 )上各种操作的时间复杂性。

票数 13
EN

Stack Overflow用户

发布于 2013-12-15 06:23:49

柜台是您的助手:

代码语言:javascript
复制
>>> from collections import Counter
>>> a = [1,2,1,3,4]
>>>  Counter(a)
Counter({1: 2, 2: 1, 3: 1, 4: 1})
>>> x = Counter(a)     
>>> x[1]
2
>>> x[2]
1

通过此方法可以轻松地获取每个元素的计数。

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/20591831

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档