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

为什么对分数比较时要用倒序

def __cmp__(self, s):
        if self.score == s.score:
            return cmp(self.name, s.name)
        return -cmp(self.score, s.score)

如上所示,为什么在比较分数时要用-cmp,不是应该分数高的排在前面吗

    def __cmp__(self,s):
        if self.score>s.score:
            return -1
        elif self.score<s.score:
            return 1
        else:
            if self.name>=s.name:
                return 1
            else :
                return -1

这是展开后的代码,为什么self.score>s.score时应该返回-1,sorted函数在比较时,不是应该前者放在前面的话应该返回1给它嘛

正在回答

2 回答

sorted(L)在进行比较时是一种迭代的比较,第一个元素与第二个元素进行比较时若返回值为1则第二个元素放在前面,反之第一个元素放在前面,以此递推。

同学,你记反了


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

饭哥 提问者

= = 谢谢!
2017-07-19 回复 有任何疑惑可以回复我~

我也有疑问,明明是比较的时候cmp(x,y),如果x>y,就返回1,这里为什么用-cmp()??

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

举报

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

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

进入课程

为什么对分数比较时要用倒序

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