栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

使用list.count使用.sort()就地对列表进行排序不起作用。为什么?

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

使用list.count使用.sort()就地对列表进行排序不起作用。为什么?

您看到的是的某些 CPython实现细节 的结果

list.sort
。再试一次,但是先创建一个副本
a

a.sort(key=a.copy().count)a# [1, 5, 5, 2, 2, 4, 4, 4]

.sort

a
内部进行修改,因此
a.count
将产生无法预测的结果。
这被记录为实现细节。

什么

copy
电话确实是它创建的副本
a
用途和 列表的
count
的关键方法。您可以看到一些调试语句会发生什么:

def count(x):    print(a)    return a.count(x)a.sort(key=count)[][][]...

a
在内部访问时会显示为空列表
.sort
,并且
[].count(anything)
将是
0
。这解释了为什么输出与输入相同-谓词都相同(
0
)。

OTOH,

sorted
创建一个新列表,因此它没有此问题。


如果您真的想按频率计数排序,惯用的方法是使用

Counter

from collections import Countera.sort(key=Counter(a).get)a# [1, 5, 5, 2, 2, 4, 4, 4]


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/641631.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号