编写函数,模拟内置函数 sorted()。

编写函数,模拟内置函数 sorted()。

用python来简单的模拟sorted可以用库函数来进行,也较为简单,我选了min()和sort()来进行模拟

利用min()函数

def sorteds(items):
    temp = items[:]
    result = [] 
    while temp:
        u = min(temp)
        result.append(u)
        temp.remove(u)
return result			#利用min函数来判断大小


利用sort()函数

def sorteds(items):
    temp = items[:]
    temp.sort()
return temp
						#直接用sort来进行sorted的操作

  • 8
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
好的,我来为您编写一个模拟 Python 内置函数 sorted() 的函数。代码如下: ```python def my_sorted(iterable, key=None, reverse=False): """ 模拟 Python 内置函数 sorted() :param iterable: 可迭代对象 :param key: 排序依据函数 :param reverse: 是否逆序排序 :return: 排序后的列表 """ # 将可迭代对象转为列表 result = list(iterable) # 如果没有指定排序依据函数,则按元素自身大小进行排序 if key is None: result.sort(reverse=reverse) else: # 使用排序依据函数进行排序 result.sort(key=key, reverse=reverse) return result ``` 这个函数接受三个参数: - `iterable`:需要排序的可迭代对象。 - `key`:排序依据函数,默认为 `None`,即按元素自身大小进行排序。 - `reverse`:是否逆序排序,默认为 `False`。 函数的返回值是排序后的列表。您可以使用如下方式来调用这个函数: ```python # 排序一个列表 my_list = [3, 1, 4, 1, 5, 9, 2, 6, 5, 3, 5] sorted_list = my_sorted(my_list) print(sorted_list) # 按元素的绝对值大小进行排序 sorted_list = my_sorted(my_list, key=abs) print(sorted_list) # 按元素的倒数进行排序 sorted_list = my_sorted(my_list, key=lambda x: 1/x) print(sorted_list) # 逆序排序 sorted_list = my_sorted(my_list, reverse=True) print(sorted_list) ``` 输出结果分别为: ``` [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9] [1, 1, 2, 3, 3, 4, 5, 5, 5, 6, 9] [9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1] [9, 6, 5, 5, 5, 4, 3, 3, 2, 1, 1] ``` 请注意,这个函数并不会改变原来的可迭代对象,而是返回一个新的列表。同时,这个函数的实现方式与 Python 内置函数 sorted() 可能有所不同,但是它们的功能是相同的。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值