通过增加 Python 中元素的频率对数组进行排序的程序
假设我们有一个包含一些元素的数组,其中元素可能出现多次。我们必须对数组进行排序,以便元素根据其频率的增加进行排序。那么哪个元素出现的次数较少将首先出现,依此类推。
因此,如果输入类似于nums=[1,5,3,1,3,1,2,5],那么输出将是[2,5,5,3,3,1,1,1]
示例(Python)
让我们看看以下实现以获得更好的理解-
def solve(nums):
mp = {}
for i in set(nums):
x=nums.count(i)
try:
mp[x].append(i)
except:
mp[x]=[i]
ans=[]
for i in sorted(mp):
for j in sorted(mp[i], reverse=True):
ans.extend([j]*i)
return ans
nums = [1,5,3,1,3,1,2,5]
print(solve(nums))输入
[1,5,3,1,3,1,2,5]输出结果
[2, 5, 5, 3, 3, 1, 1, 1]
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短