Python高级教程-sorted
Python中的排序算法
排序是程序中经常用到的算法。通常规定,对于两个元素x和y,如果认为x<y,则返回-1,如果认为x == y,则返回0,如果认为x > y,则返回1,这样,排序算法就不用关心具体的比较过程,而是根据比较结果直接进行排序。
Python内置的sorted()函数就可以对list进行排序:
>>> sorted([36,5,12,9,21])
[5, 9, 12, 21, 36]
此外,sorted()函数也是一个高阶函数,它还可以接收一个比较函数来实现自定义的排序。比如,如果要倒序排序,就可以自定义一个reversed_cmp函数:
>>> def reversed_cmp(x,y):
if x > y:
return -1
elif x == y:
return 0
else:
return 1 >>> sorted([36,5,12,9,21],reversed_cmp)
[36, 21, 12, 9, 5]
>>>
再比如字符串排序:
>>> sorted(['bob', 'about', 'Zoo', 'Credit'])
['Credit', 'Zoo', 'about', 'bob']
默认情况下,对字符串排序,是按照ASCII的大小比较的,由于‘Z’ < 'a',结果大写字母Z会排在小写字母a的前面。
如果要忽略字母的大小写呢,按照字母序排序呢:
>>> def cmp_ignore_case(s1,s2):
u1 = s1.upper()
u2 = s2.upper()
if u1 < u2:
return -1
elif u1 == u2:
return 0
else:
return 1 >>> sorted(['bob', 'about', 'Zoo', 'Credit'],cmp_ignore_case)
['about', 'bob', 'Credit', 'Zoo']
可以看出,高阶函数的抽象能力非常强大,而且核心代码可以保持非常简洁。
Python高级教程-sorted的更多相关文章
- Python高级教程
		关键字is 和 == 的区别 a = 'hello world' b = 'hello world' a == b #返回True a is b #返回False 注意:is 判断是否是一个ID, = ... 
- Python高级教程-多重继承
		多重继承 继承是面向对象编程的一个重要的方式,因为通过继承,子类可以扩展父类的功能. Animal类的层次设计,假设要实现以下4中动物: Dog - 狗狗: Bat - 蝙蝠: Parrot - 鹦鹉 ... 
- Python高级教程-filter
		Python中的filter() Python内建的filter()函数用于过滤序列.和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函数依次 ... 
- Python高级教程-Map/Reduce
		Python中的map()和reduce() Python内建了map()和reduce()函数. map() map()函数接收两个参数,一个是函数,一个是序列,map将传入的函数依次作用到序列的每 ... 
- Python高级教程-高阶函数
		Higher-order function(高阶函数) 变量可以指向函数 以Python内置的求绝对值的函数abs()为例,调用该函数用以下代码: >>> abs(-10) 10 但 ... 
- Python高级教程-生成器
		生成器(Generator) 通过列表生成式,可以直接创建一个列表.但是,受内存限制,列表的容量肯定是有限的.而且,创建一个包含100万个元素的列表,不仅占用很大的存储空间,如果我们仅仅需要访问前面几 ... 
- Python高级教程-列表生成式
		List Comprehensions(列表生成式) 列表生成式,是Python内置的非常简单却强大的可以用来创建list的生成式. 例如,要生成list:[1,2,3,4,5,6,7,8,9,10] ... 
- Python高级教程-迭代
		Python中的迭代 如果给定一个list或tuple,我们可以通过for循环来遍历这个list或tuple,这种遍历我们成为迭代(Iteration). 在Python中,迭代是通过for...in ... 
- Python高级教程-切片
		Python中的切片 取一个list或tuple的部分元素是非常常见的操作.比如,一个list如下: >>> L = ['A','B','C','D'] 对经常取指定索引范围的操作, ... 
随机推荐
- 陷阱:C++模块之间的”直接依赖“和”间接依赖“与Makefile的撰写
			参考:http://make.mad-scientist.net/papers/advanced-auto-dependency-generation/ 参考:http://stackoverflow ... 
- 关于 web中 使用 java.net.URLEncoder.encode  要编码两次呢  , js的encodeURIComponent 同理
			因为在jsp中对中文进行了编码的时候用的是UTF-8的编码方式,而在servlet中调用request.getParameter();方法的时候使用服务器指定的原始编码格式(ISO-8859-1)自动 ... 
- ListView嵌套GridView使用详解及注意事项
			ListView嵌套GridView即ListView的每个Item中都包含一个GridView:需要注意的是由于ListView和GridView都是可滑动的控件. 所以需要自定义GridView, ... 
- Extjs的完成按钮和位置
			this.toolbar.add('->') ---重点是这个箭头,他是控制位置的 this.CompleteDataAction = new Ext.Action({ text : '完成', ... 
- nginx配置事例
			#user nobody; worker_processes 4; #error_log logs/error.log; #error_log logs/error.log notice; #erro ... 
- TCP/IP各层协议数据格式
			ISO规范里定义了7层网络模型,实际常用的仍为TCPIP四层网络模型. 注:本文章插图均来自<图解TCP/IP>. 数据链路层帧格式 经常说的帧格式为以太网帧格式,由于类型和帧长度字段不重 ... 
- Linux下vi命令小结
			进入vi的命令 vi filename :打开或新建文件,并将光标置于第一行首 vi n filename :打开文件,并将光标置于第n行首 vi filename :打 ... 
- kettle的job中使用循环
			 job中使用循环 在一个不稳定的网络环境下作文件传输.偶尔会有超时或连接重置.这时须要稍等片刻再重试.在重试10次之后放弃并结束该job.类似使用循环解决这类问题. 该演示样例job演示了这样 ... 
- Socket创建失败:10093错误
			10093的错误,应用程序没有调用 WSAStartup,或者 WSAStartup 失败. 问题描述:Failed to create UDP socket:10093!Close and rest ... 
- js阻止表单提交
			<!DOCTYPE html><html><head> <title>Simple Login Form</title> < ... 
