课程
/后端开发
/Python
/python进阶
def reversed_cmp(x, y): if x > y: return -1 if x < y: return 1 return 0
这个函数中的1, - 1是不是可以理解为排序的移动?
2018-09-19
源自:python进阶 2-7
正在回答
刚开始我看了半天也没看懂和你疑问一样,后来我觉得意思应该是,sorted()的内部比较函数和我们定义的函数cmp_ignore_case(s1, s2)都是独立的个体
sort()它被要求执行的任务的比较函数:如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1。如果 x 和 y 相等,返回 0。所以要是想倒序的话,就是大的排在前面,所以数字x>y应该是返回-1
而题中间则是要顺序排首字母大小,所以小的排在前面,所以x<y返回-1
哎我罗里吧嗦其实自己还是也没太弄懂
不能这么理解吧,就reversed_cmp方法而言仅仅是判断出两个变量之间的大小关系,但它并不清楚自己会被什么其他方法调用去干什么;而sorted方法刚刚好就需要reversed_cmp这样的方法来做排序的规则,具体的排序移动应该是sorted内部实现。
pythonMiya 提问者
举报
学习函数式、模块和面向对象编程,掌握Python高级程序设计