wy121221612
六花の勇士
采纳率66.7%
2020-02-21 20:37 阅读 587

python sorted排序问题

问题描述:

排序规则:

正数在前负数在后;正数从小到大;负数从大到小

例如:

排序前[7,-8,5,4,0,-2,-5]

排序后:[0,4,5,7,-2,-5,-8]

补全代码以下代码:

sorted(lst,key=lambda x : ___)

我的解决方法:

(sorted(lst,key=lambda  x:abs(x*10) if x < 0 else x)

这个方法存在bug,正数过大时排序出问题。暂时想不到更好的方法,求助大佬解答

  • 点赞
  • 写回答
  • 关注问题
  • 收藏
  • 复制链接分享

2条回答 默认 最新

  • 已采纳
    chenghsiutso chenghsiutso 2020-02-22 04:29

    sorted(lst, key=lambda x:-x if x < 0 else x - max(lst))

    点赞 评论 复制链接分享
  • caozhy 从今以后生命中的每一秒都属于我爱的人 2020-02-21 21:49

    没有绝对的正确,这样写试试看

    list.sort(key=lambda x:x*-100 if x<0 else x )
    
    点赞 评论 复制链接分享

相关推荐