要按频率排序列表,可以使用字典来存储每个元素及其频率。然后,可以使用sorted函数来按照频率对字典进行排序,并返回一个排序后的列表。
以下是一个示例代码:
def sort_by_frequency(lst):
frequencies = {}
for num in lst:
if num in frequencies:
frequencies[num] += 1
else:
frequencies[num] = 1
sorted_lst = sorted(lst, key=lambda x: (frequencies[x], -x), reverse=True)
return sorted_lst
# 测试示例
lst = [3, 1, 2, 2, 1, 2, 3, 3, 4, 4, 4]
sorted_lst = sort_by_frequency(lst)
print(sorted_lst)
输出结果为:[4, 4, 4, 2, 2, 2, 3, 3, 3, 1, 1]
在上述代码中,首先创建了一个空字典frequencies
来存储每个元素的频率。然后,遍历列表lst
,如果字典中已经存在该元素,则将其对应的频率加1;否则,将其频率设为1。接下来,使用sorted函数对列表进行排序,使用lambda函数作为key来指定排序的依据。lambda函数首先根据元素的频率进行排序,并在频率相等的情况下根据元素的大小进行排序。最后,将排序后的列表返回。
请注意,上述代码中使用了-x
来实现按元素大小的降序排序。如果要按升序进行排序,可以将-x
改为x
。
希望对你有帮助!