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

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))

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

悬赏问题

  • ¥15 软件定义网络mininet和onos控制器问题
  • ¥15 微信小程序 用oss下载 aliyun-oss-sdk-6.18.0.min client报错
  • ¥15 ArcGIS批量裁剪
  • ¥15 labview程序设计
  • ¥15 为什么在配置Linux系统的时候执行脚本总是出现E: Failed to fetch http:L/cn.archive.ubuntu.com
  • ¥15 Cloudreve保存用户组存储空间大小时报错
  • ¥15 伪标签为什么不能作为弱监督语义分割的结果?
  • ¥15 编一个判断一个区间范围内的数字的个位数的立方和是否等于其本身的程序在输入第1组数据后卡住了(语言-c语言)
  • ¥15 Mac版Fiddler Everywhere4.0.1提示强制更新
  • ¥15 android 集成sentry上报时报错。