Python: 编写函数,模拟Python内置函数sorted()
时间: 2024-07-01 14:00:53 浏览: 94
Python的`sorted()`函数是一个非常实用的内置函数,它接收一个可迭代对象作为参数,返回一个新的排序后的列表,但不会改变原对象。如果你想要编写一个模拟`sorted()`函数的简单函数,你可以使用Python的列表推导式和条件判断来实现。以下是一个简单的实现:
```python
def custom_sort(iterable, key=None, reverse=False):
"""
模拟Python内置函数sorted(),对可迭代对象进行排序。
参数:
iterable (list或tuple): 需要排序的元素列表或元组
key (函数, optional): 用于指定排序依据的函数。默认为None,按值排序。
reverse (bool, optional): 是否降序排列。默认为False,升序排列。
返回:
list: 排序后的列表
"""
# 如果没有key参数,直接对元素排序
if key is None:
return sorted(iterable, reverse=reverse)
# 如果有key参数,根据key函数的结果进行排序
else:
return sorted(iterable, key=key, reverse=reverse)
# 示例用法
numbers = [5, 2, 8, 1, 9]
print(custom_sort(numbers)) # 升序排序:[1, 2, 5, 8, 9]
print(custom_sort(numbers, reverse=True)) # 降序排序:[9, 8, 5, 2, 1]
```