要按频率排列一个列表中的元素,可以使用字典来记录每个元素的出现次数。然后,根据元素的出现次数进行排序,最后重新构建排序后的列表。
以下是一个示例代码:
def sortByFrequency(arr):
# 使用字典来记录每个元素的出现次数
freq = {}
for num in arr:
if num in freq:
freq[num] += 1
else:
freq[num] = 1
# 根据元素的出现次数进行排序
sorted_freq = sorted(freq.items(), key=lambda x: x[1])
# 重新构建排序后的列表
sorted_arr = []
for item in sorted_freq:
num, count = item
sorted_arr.extend([num] * count)
return sorted_arr
# 示例输入
arr = [4, 2, 2, 8, 3, 3, 1]
# 输出 [4, 8, 1, 2, 2, 3, 3]
print(sortByFrequency(arr))
在上述代码中,首先创建一个空字典freq来记录每个元素的出现次数。然后,遍历输入列表arr,如果当前元素已经在字典freq中,则将其出现次数加1,否则将其初始出现次数设为1。
接下来,使用sorted()函数和lambda表达式对字典freq进行排序,排序依据是元素的出现次数。
最后,通过遍历排序后的字典freq,将每个元素按照出现次数的多少依次添加到sorted_arr列表中。
这样,我们就可以得到按频率排列后的列表sorted_arr。
上一篇:按频率降序排序的列表
下一篇:按频率排序的列