首页 > 编程语言 > 详细

python 自定义排序函数

时间:2016-07-29 16:41:40      阅读:360      评论:0      收藏:0      [点我收藏+]
自定义排序函数

Python内置的 sorted()函数可对list进行排序:

>>>sorted([36, 5, 12, 9, 21])
[5, 9, 12, 21, 36]

但 sorted()也是一个高阶函数,它可以接收一个比较函数来实现自定义排序,比较函数的定义是,传入两个待比较的元素 x, y,如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1。如果 x 和 y 相等,返回 0。

因此,如果我们要实现倒序排序,只需要编写一个reversed_cmp函数:

def reversed_cmp(x, y):
    if x > y:
        return -1
    if x < y:
        return 1
    return 0
这样,调用 sorted() 并传入 reversed_cmp 就可以实现倒序排序:

>>> sorted([36, 5, 12, 9, 21], reversed_cmp)
[36, 21, 12, 9, 5]
sorted()也可以对字符串进行排序,字符串默认按照ASCII大小来比较:

>>> sorted([bob, about, Zoo, Credit])
[Credit, Zoo, about, bob]
Zoo排在about之前是因为Z的ASCII码比a小




任务
对字符串排序时,有时候忽略大小写排序更符合习惯。请利用sorted()高阶函数,实现忽略大小写排序的算法。

输入:[bob, about, Zoo, Credit]
输出:[about, bob, Credit, Zoo]


def cmp_ignore_case(s1, s2):
    t1=s1.lower();
    t2=s2.lower();
    if(t1>t2):
        return 1
    if(t1==t2):
        return 0
    return -1

print sorted([bob, about, Zoo, Credit], cmp_ignore_case)

 

python 自定义排序函数

原文:http://www.cnblogs.com/superxuezhazha/p/5718829.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!