zoukankan      html  css  js  c++  java
  • python中使用heapq查看最大与最小的N个元素列表

    怎么从一个集合中获取最大或最小的N个元素列表?

    heapq模块有两个函数:nlargest() 和 nsmallest() 可以完美解决这个问题。

    In [39]: import heapq
    
    In [40]: nums = [2, 5, 3, 4]
    
    In [41]: heapq.nlargest(2,nums)
    Out[41]: [5, 4]
    
    In [42]: heapq.nsmallest(2,nums)
    Out[42]: [2, 3]

    两个函数都能接受一个关键字参数,用于更复杂的数据结构中:

    以price值进行比较

    portfolio = [
        {'name': 'IBM', 'shares': 100, 'price': 91.1},
        {'name': 'AAPL', 'shares': 50, 'price': 543.22},
        {'name': 'FB', 'shares': 200, 'price': 21.09},
        {'name': 'HPQ', 'shares': 35, 'price': 31.75},
        {'name': 'YHOO', 'shares': 45, 'price': 16.35},
        {'name': 'ACME', 'shares': 75, 'price': 115.65}
    ]
    cheap = heapq.nsmallest(3, portfolio, key=lambda s: s['price'])
    expensive = heapq.nlargest(3, portfolio, key=lambda s: s['price'])

    In [33]: heapq.nlargest(3, portfolio, key=lambda s: s['price'])
    Out[33]:
    [{'name': 'AAPL', 'price': 543.22, 'shares': 50},
    {'name': 'ACME', 'price': 115.65, 'shares': 75},
    {'name': 'IBM', 'price': 91.1, 'shares': 100}]

    等于

    In [34]: sorted(portfolio, key=lambda s: s['price'],reverse=True)[:3]
    Out[34]:
    [{'name': 'AAPL', 'price': 543.22, 'shares': 50},
    {'name': 'ACME', 'price': 115.65, 'shares': 75},
    {'name': 'IBM', 'price': 91.1, 'shares': 100}]

    对字典排序

    In [21]: a = {'a': 1, 'b': 2, 'c': 4, 'd': 3}
    按字典值排序
    In [22]: sorted(a.items(), key=lambda s: s[1])
    Out[22]: [('a', 1), ('b', 2), ('d', 3), ('c', 4)]
    按字典键排序
    In [23]: sorted(a.items(), key=lambda s: s[0])
    Out[23]: [('a', 1), ('b', 2), ('c', 4), ('d', 3)]

                 

  • 相关阅读:
    Range
    cache
    从头到尾彻底解析Hash 表算法
    教你如何迅速秒杀掉:99%的海量数据处理面试题
    秒杀抢购思路以及高并发下数据安全
    Nginx+Tomcat负载均衡
    强大的Spring缓存技术(上)
    强大的Spring缓存技术(中)
    强大的Spring缓存技术(下)
    (转)C#中的 break 与continue 的使用和注意
  • 原文地址:https://www.cnblogs.com/xiaoming279/p/6230391.html
Copyright © 2011-2022 走看看