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

关于python中的自定义排序,比如numbe=[5,9,3,4] 然后自定义排序 为什么使用number.sort(cmp)就可以实现呢,,,cmp()函数返回的不是 1,-1,和0吗 在sort()里边怎么实现的 求解答 谢谢

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


正在回答

2 回答

sorted排序过程需要确定哪个在前哪个在后,元素a,b的先后权值是根据调用reversed_cmp(a,b) 得到的返回值1,-1,0确定的,返回值<0,sorted会把a放到b的前面,>0会把a放到b的后面,返回0则不改变它们的相对位置


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

慕慕3083393 提问者

非常感谢!
2016-04-14 回复 有任何疑惑可以回复我~

1就正序,-1就逆序

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

慕慕3083393 提问者

我是不理解比如6和8比较 然后返回-1 之后这个序列怎样变化的
2016-03-14 回复 有任何疑惑可以回复我~

举报

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

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

进入课程

关于python中的自定义排序,比如numbe=[5,9,3,4] 然后自定义排序 为什么使用number.sort(cmp)就可以实现呢,,,cmp()函数返回的不是 1,-1,和0吗 在sort()里边怎么实现的 求解答 谢谢

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