为了账号安全,请及时绑定邮箱和手机立即绑定

-1,1 是否可以理解为向后向前移动排序?

def reversed_cmp(x, y):
    if x > y:
        return -1
    if x < y:
        return 1
    return 0


这个函数中的1, - 1是不是可以理解为排序的移动?


正在回答

2 回答

刚开始我看了半天也没看懂和你疑问一样,后来我觉得意思应该是,sorted()的内部比较函数和我们定义的函数cmp_ignore_case(s1, s2)都是独立的个体

sort()它被要求执行的任务的比较函数:如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1。如果 x 和 y 相等,返回 0。所以要是想倒序的话,就是大的排在前面,所以数字x>y应该是返回-1

而题中间则是要顺序排首字母大小,所以小的排在前面,所以x<y返回-1

哎我罗里吧嗦其实自己还是也没太弄懂

0 回复 有任何疑惑可以回复我~

不能这么理解吧,就reversed_cmp方法而言仅仅是判断出两个变量之间的大小关系,但它并不清楚自己会被什么其他方法调用去干什么;而sorted方法刚刚好就需要reversed_cmp这样的方法来做排序的规则,具体的排序移动应该是sorted内部实现。

0 回复 有任何疑惑可以回复我~
#1

pythonMiya 提问者

感谢答复,虽然我还是不能理解,慢慢学咯:)
2018-09-20 回复 有任何疑惑可以回复我~

举报

0/150
提交
取消
python进阶
  • 参与学习       255665    人
  • 解答问题       2949    个

学习函数式、模块和面向对象编程,掌握Python高级程序设计

进入课程

-1,1 是否可以理解为向后向前移动排序?

我要回答 关注问题
意见反馈 帮助中心 APP下载
官方微信