美文网首页
排序常用方法

排序常用方法

作者: 心水Diana | 来源:发表于2019-02-25 15:02 被阅读0次
  • 列表内置函数sort
# sort是会影响列表本身
lis = [4,5,68,46,4,]
lis.sort()
print(lis)
[4, 4, 5, 46, 68]

sorted

  • 字典排序
dic = {0: 9, 1: 0, 2: 3, 3: 3, 4: 1, 5: 7, 6: 4}
# 将字典items键值对组成元组传入,取每个元组[1]元素进行排序,reverse表示升降序
b = dict(sorted(dic.items(),key=lambda x:x[1],reverse=True))
print(b)
{0: 9, 5: 7, 6: 4, 2: 3, 3: 3, 4: 1, 1: 0}
  • 列表内嵌字典
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}
]

a = sorted([i for i in portfolio],key=lambda x:x['price'],reverse=True)

print(a)
  • 模块heapq方法
    • 传入三个参数, nsmallest(n, iterable, key=None)
    • n -> 排序的数量
    • iterable -> 要排序的可迭代对象
    • key -> 排序的关键字
import heapq

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(len(portfolio),portfolio, key=lambda s: s['price'])
print(cheap)
[{'name': 'YHOO', 'price': 16.35, 'shares': 45},
 {'name': 'FB', 'price': 21.09, 'shares': 200},
 {'name': 'HPQ', 'price': 31.75, 'shares': 35},
 {'name': 'IBM', 'price': 91.1, 'shares': 100},
 {'name': 'ACME', 'price': 115.65, 'shares': 75},
 {'name': 'AAPL', 'price': 543.22, 'shares': 50}]

# 降序
expensive = heapq.nlargest(3, portfolio, key=lambda s: s['price'])
print(expensive)
[{'name': 'AAPL', 'price': 543.22, 'shares': 50},
 {'name': 'ACME', 'price': 115.65, 'shares': 75},
 {'name': 'IBM', 'price': 91.1, 'shares': 100}]

相关文章

  • 冒泡排序、插入排序、选择排序

    一、排序方法与复杂度归类 几种最经典、最常用的排序方法:冒泡排序、插入排序、选择排序、快速排序、归并排序、计数排序...

  • 排序(上)

    排序方法与复杂度归类 (1)几种最经典、最常用的排序方法:冒泡排序、插入排序、选择排序、快速排序、归并排序、计数排...

  • 理解6:Collections

    Collections 工具类常用方法: 排序 替换、查找 排序 示例 查找、替换 示例

  • 选择排序法

    常用的选择排序方法有两种:直接选择排序和堆排序。直接排序简单直观,但性能略差;堆排序是一种较为高效的选择排序方法,...

  • 排序常用方法

    列表内置函数sort sorted 字典排序 列表内嵌字典 模块heapq方法传入三个参数, nsmallest(...

  • java排序方法资料

    java排序,效率高的是哪种排序方法 JAVA快速排序(高效) java中常用的几种排序算法 相关代码: /* *...

  • JavaScript的排序算法——选择排序

    选择排序(Selection Sort) 选择排序是一种排序算法,是一个占用常用内存(In-place)的排序方法...

  • 前端er常用的几种排序方法

    前端常用的排序方法有:冒泡排序,选择排序,快速排序,插入排序 一、冒泡排序 理解冒泡排序 相邻的两个元素依次比较,...

  • JavaScript算法入门--排序--冒泡排序

    一般排序的常用方法有:冒泡法、插入法、选择法、快速排序、归并排序、桶排序、希尔排序、堆排序、基数排序、外部排序等。...

  • JavaScript算法入门--排序--插入排序

    一般排序的常用方法有:冒泡法、插入法、选择法、快速排序、归并排序、桶排序、希尔排序、堆排序、基数排序、外部排序等。...

网友评论

      本文标题:排序常用方法

      本文链接:https://www.haomeiwen.com/subject/xekgyqtx.html