Python高阶函数-sorted(深度解析从原理到实战)

在这里插入图片描述

一、sorted()函数概述

sorted()是Python内置的高阶函数,用于对可迭代对象进行排序操作。与列表的sort()方法不同,sorted()会返回一个新的已排序列表,而不改变原数据。

基本语法

sorted(iterable, *, key=None, reverse=False)

二、核心参数详解

1. iterable(必需参数)

任何可迭代对象(列表、元组、字符串、字典等)

2. key(关键参数)

  • 接受一个函数作为参数
  • 该函数会被应用到每个元素上,根据函数返回值进行排序
  • 默认值为None,表示直接比较元素本身

3. reverse(排序方向)

  • 布尔值参数
  • False表示升序(默认)
  • True表示降序

三、底层实现原理

sorted()内部使用TimSort算法(一种混合了归并排序和插入排序的稳定算法):

  • 时间复杂度:O(n log n)
  • 空间复杂度:O(n)
  • 稳定性:保持相等元素的原始顺序
# 伪代码展示基本逻辑
def sorted(iterable, key=None, reverse=False):
    # 1. 获取可迭代对象的元素列表
    elements = list(iterable)
    
    # 2. 如果有key函数,应用转换
    if key is not None:
        decorated = [(key(x), i, x) for i, x in enumerate(elements)]
    else:
        decorated = elements
    
    # 3. 执行TimSort排序
    decorated.sort()
    
    # 4. 还原原始数据(保持稳定性)
    if key is not None:
        result = [x for (k, i, x) in decorated]
    e
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Aerkui

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值