python 中sorted 和sort
2016-04-07 00:00
351 查看
摘要: sorted是python内置的排序函数,如何使用这个函数返回排序后的元素的index的列表
sorted 和sort是python内置的函数
但是sort是列表的函数,而sorted直接对容器进行操作,返回一个新的容器,容器可以是list,tuple,可迭代对象等。
a.sort()排序后会改变a。而sorted(a)会返回一个排序后的容器,a并不变化。
实际测试sorted比sort速度快。
用help(sorted)查看帮助得到:
第一个参数是可迭代对象,第二个参数是用来比较的关键字。sorted函数是返回iterable按照key参数制定的关键字排序后的新的列表。
sorted 和sort是python内置的函数
但是sort是列表的函数,而sorted直接对容器进行操作,返回一个新的容器,容器可以是list,tuple,可迭代对象等。
a.sort()排序后会改变a。而sorted(a)会返回一个排序后的容器,a并不变化。
实际测试sorted比sort速度快。
返回下标index
numpy 中有个函数argsort()可以返回排序后的下标。对于列表s=[2, 3, 1, 4, 5],
numpy.argsort(s)的返回值是array([2, 0, 1, 3, 4]),这个表示排序的列表[1, 2, 3, 4, 5]中元素对应于s中的下标为[2, 0, 1, 3, 4]。使用lettcode刷题时,不能导入包。所以只能用其他方式来实现这个功能。sorted就可以实现。
sorted(range(len(s)), key=lambda k: s[k])的返回值就是[2, 0, 1, 3, 4]。
用help(sorted)查看帮助得到:
sorted(iterable, key=None, reverse=False) --> new sorted list
第一个参数是可迭代对象,第二个参数是用来比较的关键字。sorted函数是返回iterable按照key参数制定的关键字排序后的新的列表。
sorted(range(len(s)), key=lambda k: s[k])则是返回range(lens)按照关键字s[k]排序后的结果。(k是从第一个参数range(lens)中取元素)
相关文章推荐
- Python动态类型的学习---引用的理解
- Python3写爬虫(四)多线程实现数据爬取
- 垃圾邮件过滤器 python简单实现
- 下载并遍历 names.txt 文件,输出长度最长的回文人名。
- install and upgrade scrapy
- Scrapy的架构介绍
- Centos6 编译安装Python
- 使用Python生成Excel格式的图片
- 让Python文件也可以当bat文件运行
- [Python]推算数独
- 在命令行用 sort 进行排序
- Python中zip()函数用法举例
- Python中map()函数浅析
- Python将excel导入到mysql中
- Python在CAM软件Genesis2000中的应用
- 使用Shiboken为C++和Qt库创建Python绑定
- FREEBASIC 编译可被python调用的dll函数示例