python 自定义排序函数

自定义排序函数

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)
时间: 2024-12-25 22:04:48

python 自定义排序函数的相关文章

python中自定义排序函数

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函数: de

python之自定义排序函数sorted()

sorted()也是一个高阶函数,它可以接收一个比较函数来实现自定义排序,比较函数的定义是,传入两个待比较的元素 x, y,如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1.如果 x 和 y 相等,返回 0. def custom_sort(x,y): if x>y: return -1 if x<y: return 1 return 0 print sorted([2,4,5,7,3],custom_sort) 在python3以后,sort方法和sort

MySQL自定义排序函数FIELD()

MySQL可以通过field()函数自定义排序,格式:field(value,str1,str2,str3,str4),value与str1.str2.str3.str4比较,返回1.2.3.4,如遇到null或者不在列表中的数据则返回0. mysql> select * from driver_log order by field(name,'Suzi','Ben','Henry'); +--------+-------+------------+-------+ | rec_id | nam

python 自定义回调函数

回调函数用起来比较爽.特别是在js中,满世界全是回调,那么在python中,怎么来优雅地实现自己的回调函数呢 下面贴一个我写的例子 class BaseHandler(object): def crawl(self, url, **kwargs): if kwargs.get('callback'): callback = kwargs['callback'] if isinstance(callback, basestring) and hasattr(self, callback): fun

Java当中自定义排序函数

一.实现Comparator接口 方法类似Merge two sorted list中介绍的,包括了有名类和匿名类两种方式 具体使用: 排序: Collections.sort(容器,comparator) Queue q = new PriorityQueue(capacity,comparator) 二.comparable 抽象类

python自定义日志函数测试

#!/user/bin/python# -*- encoding: UTF-8 -*- import sys def logs(): print sys._getframe().f_code.co_name print sys._getframe().f_lineno print sys._getframe().f_back.f_code.co_name print sys._getframe().f_back.f_lineno def get_cur_info() : logs() get_c

python的排序函数

1.sort和sorted eg: a = [5,2,1,9,6] sorted(a)    #将a从小到大排序,不影响a本身结构 a.sort()     #将a从小到大排序,影响a本身结构 a.sort(reverse=True)    #将a从大到小排序,影响a本身结构 2.二维list按某列排序 lis = [[4, 2, 9], [1, 5, 6], [7, 8, 3]]lis.sort(key=lambda k: k[2]) 备注:k[2]即为第2列(编号从0开始) 原文地址:htt

Problem D: 指针:调用自定义排序函数sort,对输入的n个数进行从小到大输出。

#include<stdio.h> int sort(int *p,int n) { int i,j,temp; for(i=0;i<n-1;i++) for(j=i;j<n;j++) if(p[i]>p[j]) { temp=p[i]; p[i]=p[j]; p[j]=temp; } } int main() { int n,a[100],i; while(scanf("%d",&n)!=EOF) { for(i=0;i<n;i++) sc

c++ stl sort 自定义排序函数cmp要遵循 strict weak ordering

满足strict weak ordering的运算符能够表达其他所有的逻辑运算符(logical operator): <(a, b)  : (a < b) <=(a, b): !(b < a) ==(a, b): !(a < b) && !(b < a) !=(a, b) : (a < b) || (b < a) >(a, b)  : (b < a) >=(a, b): !(a < b) 引用自https://www