Python统计列表(List)中的重复项出现的次数并进行排序
发布日期:2021-06-03 08:57:40 浏览次数:9 分类:技术文章

本文共 1752 字,大约阅读时间需要 5 分钟。


学习Python的过程中,你会遇到各种各样的坑,不要觉得难,当你去踩过就会觉得很简单了!


正文:


  • 题目概述
    对于一个列表,比如List = [1,2,3,4,5,3,2,1,4,5,6,4,2,3,4,6,2,2],现在我们需要统计这个列表中的重复项,统计出重复次数后,按照我们自己的要求进行排序。

实现方法:


  • 统计重复项出现次数:

    • 方法一:

      List = [1,2,3,4,5,3,2,1,4,5,6,4,2,3,4,6,2,2]
      List_set = set(List) #List_set是另外一个列表,里面的内容是List里面的无重复 项
      for item in List_set:
      print("the %d has found %d" %(item,List.count(item)))

    • 方法二:(利用字典的特性来实现)

      List=[1,2,3,4,5,3,2,1,4,5,6,4,2,3,4,6,2,2]
      a = {}
      for i in List:
      if List.count(i)>1:
      a[i] = List.count(i)
      a = sorted(a.items(), key=lambda item:item[0])
      print (a)

    • 方法三:from collections import Counter

      List=[1,2,3,4,5,3,2,1,4,5,6,4,2,3,4,6,2,2]
      Counter(list)

    • 方法四:(只用列表来进行实现)
      List=[1,2,3,4,5,3,2,1,4,5,6,4,2,3,4,6,2,2]
      count_times = []
      for i in l :
      count_times.append(l.count(i))
      m = max(count_times)
      n = l.index(m)
      print (list[n])
      实现原理:把列表中的每一个数出现的次数在其对应的位置上记录下来,然后用max求出出现次数最多的位置。但有一个缺点,如果有多个结果,最后的实现结果只是出现在最左边的那个上,不过要改进也很简单,感兴趣的同学可以想一下如何解决这个小bug

PS:

在这里安利一波对Python中的字典进行排序的方法:(不是特别深刻的介绍原理,大家要深究的童鞋可以去仔细探究一下)


先简单介绍一下sorted()函数:

sorted(iterable,key,reverse),sorted一共有iterable,key,reverse这三个参数。

其中iterable表示可以迭代的对象,例如可以是dict.items()、dict.keys()等,key是一个函数,用来选取参与比较的元素,reverse则是用来指定排序是倒序还是顺序,reverse=true则是倒序,reverse=false时则是顺序,默认时reverse=false。
特别注意:在按值排序的过程中,item是items中的一个元素,这里就是固定用item,而不是用字典dic


  • 按照键(key)进行排序

    • 升序:

      dic = {'a':15, 'e':13, 'd':45, 'b':10}
      dic = sorted(dic.items(), key = lambda dic:dic[0])
      print(dic)

    • 降序:

      dic = {'a':15, 'e':13, 'd':45, 'b':10}
      dic = sorted(dic.items(), key = lambda dic:dic[0] reverse = True)
      print(dic)

  • 按照值(value)进行排序
    • 升序:
      dic = {'a':15, 'e':13, 'd':45, 'b':10}
      dic = sorted(dic.items(), key = lambda item:item[1])
      print(dic)
    • 降序:
      dic = {'a':15, 'e':13, 'd':45, 'b':10}
      dic = sorted(dic.items(), key = lambda item:item[1] reverse = True)
      print(dic)

祝各位能有所获!

转载地址:https://blog.csdn.net/HuaCode/article/details/79763687 如侵犯您的版权,请留言回复原文章的地址,我们会给您删除此文章,给您带来不便请您谅解!

上一篇:NS-3网络仿真平台搭建及可视化
下一篇:scrapy运行问题:IndexError: list index out of range

发表评论

最新留言

很好
[***.229.124.182]2024年03月24日 22时56分10秒

关于作者

    喝酒易醉,品茶养心,人生如梦,品茶悟道,何以解忧?唯有杜康!
-- 愿君每日到此一游!

推荐文章

【大话Mysql面试】-Mysql事务以及隔离级别 2019-04-26
【大话Mysql面试】-Mysql索引 2019-04-26
【大话Mysql面试】-Mysql锁 2019-04-26
【大话Mysql面试】-Mysql常见面试题目 2019-04-26
08 【多线程高并发】Java线程间通信的方式 2019-04-26
【数据结构与算法】什么是跳表?通俗易懂来理解跳表 2019-04-26
【数据结构与算法】什么是图?图是什么?快速带你回顾图有关的知识点 2019-04-26
【数据结构与算法】什么是串?什么是KMP算法?字符串匹配是什么? 2019-04-26
【数据结构与算法】什么是布隆过滤器?如何防止缓存穿透的问题? 2019-04-26
【Java锁体系】CopyOnWriteArrayList是什么?线程安全的arraylist是哪个? 2019-04-26
【面试题目】Java设计模式你有哪些了解?说几个常用的。 2019-04-26
【计算机操作系统】常说的死锁是什么?死锁产生的必要条件是什么?死锁的解决策略是什么? 2019-04-26
【计算机操作系统】进程管理详解?进程与线程区别是什么?进程调度的算法有哪些?进程通信有哪些? 2019-04-26
【计算机操作系统】虚拟内存是什么?分页系统地址映射?页面置换算法有哪些?分段地址映射又是什么? 2019-04-26
【计算机操作系统】设备管理?磁盘结构是怎么样的?磁盘调度算法有哪些? 2019-04-26
【多线程高并发】为什么要使用多线程?创建多少个线程合适呢? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印1-100两个数?多线程轮流打印数字? 2019-04-26
【多线程与高并发】 Java两个线程轮流打印字符串? 2019-04-26
【Linux命令篇】Linux命令实践 2019-04-26
【Leetcode单调队列】Leetcode239 滑动窗口最大值 2019-04-26