六花の勇士 2020-02-21 20:37 采纳率: 0%
浏览 694
已采纳

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 2020-02-22 04:29
    关注

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

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
  • threenewbee 2020-02-21 21:49
    关注

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

    list.sort(key=lambda x:x*-100 if x<0 else x )
    
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 Java中import为灰色
  • ¥15 手机等其他智能设备被监听
  • ¥15 在win10 64位的vs打包MSI文件,放到win7 64位上安装成可执行exe文件后,点击程序不运行。
  • ¥50 大众点评用户浏览/消费记录爬虫
  • ¥15 求制作一个个人网页,
  • ¥15 寻涂色内存脚本作者有项目有市场有资源.却技术
  • ¥15 蓝桥杯c51单片机问题
  • ¥15 ajax跨域问题请求修改代码
  • ¥15 python matplotlib
  • ¥15 短信测压+语音,有偿,必须用Python