码迷,mamicode.com
首页 > 编程语言 > 详细

python小练习:给定一个非空且为正整数的列表 按重复次数 降序排列输出

时间:2018-03-06 15:38:21      阅读:128      评论:0      收藏:0      [点我收藏+]

标签:key   一个   end   style   ==   post   print   log   gpo   

假设有个列表  a=[1,1,1,2,2,4,5,5,5,5] (非空且为正整数)

那么根据要求 最终输出的形式为  5,1,2,4  (按重复次数 降序排列输出)

 

代码实现及解释:

a=[1,1,1,2,2,4,5,5,5,5]
num=[]

for i in a:
s = a.count(i)
num.append(s)#取出数字出现的次数 放进num中

num1 = sorted(num,reverse=True)# 降序排列num 并赋值给num1
num2=list(set(num1))#去重并转换成列表类型 (注:去重后 元素显示是无序的)
num2.sort(key=num1.index)#按原来num1的顺序排序 (对应最终按要求输出的 a列表里面的值 这一步很关键)
num3=[]

for x in num2:
for i in a:
if x ==a.count(i):
num3.append(i)#取出次数对应a列表里面的值放进新列表num3中 num3中的元素和a列表里面的元素一样 只是顺序是按重复的次数显示 且元素有重复值
else:
pass
num4=[]
for j in num3:
if j not in num4:
num4.append(j)#去重
print(num4)
 

最后输出为:[5, 1, 2, 4]

 

这边有个知识点   列表去重后 并按原来的顺序排序:

num2=list(set(num1))#去重并转换成列表类型  (注:去重后 元素显示是无序的)
num2.sort(key=num1.index)#按原来num1的顺序排序 (对应最终按要求输出的 a列表里面的值 这一步很关键)

 

 

python小练习:给定一个非空且为正整数的列表 按重复次数 降序排列输出

标签:key   一个   end   style   ==   post   print   log   gpo   

原文地址:https://www.cnblogs.com/dwtt/p/8514514.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!