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

当sorted()函数接受比较函数来实现自定义排序时,具体的运算流程是什么?

为什么加了reversed_cmp函数之后就能实现倒序,具体流程是冒泡法进行排序吗?
还有一个问题就是题目中如果出现两个首字母相同的情况的话,那该怎么排序?
def cmp_ignore_case(s1, s2):
    if s1.lower() > s2.lower():
        return 1
    if s1.lower() < s2.lower():
        return -1
    return 0
print sorted(['aob', 'about', 'Zoo', 'Credit'], cmp_ignore_case)
比如我将bob改为aob,此时运行结果就是['about', 'aob', 'Credit', 'Zoo'],为什么aob和about的顺序改变了?

正在回答

1 回答

1、对于sorted()的定义是,传入两个待比较的元素 x, y,如果 x 应该排在 y 的前面,返回 -1,如果 x 应该排在 y 的后面,返回 1。如果 x 和 y 相等,返回 0。至于加了reversed_cmp函数之后实现倒序是因为和上面的排序定义正好相反

2、如果比较的字符串中的首字母一样,就比较下一个字母么

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

慕村0147906 提问者

前阵子个人原因没有时间学习python,刚刚恢复学习,所以采纳晚了,谢谢你的回答!
2017-09-08 回复 有任何疑惑可以回复我~

举报

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

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

进入课程

当sorted()函数接受比较函数来实现自定义排序时,具体的运算流程是什么?

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