LeetCode 剑指offer45 把数组排成最小的数 题解 ——>自定义排序规则functools.cmp_to_key( )

该博客讨论了如何处理整数数组排序的问题,尤其是在排序包含前导零的数字时。作者通过创建一个自定义排序规则函数sort_rule,确保排序结果符合预期,如320在32之前。代码中,nums数组转换为字符串数组后,使用sort函数并指定key参数为sort_rule进行排序,最后使用join方法将排序后的字符串数组合并为一个字符串。
摘要由CSDN通过智能技术生成

我的思路:

1.将nums变成字符串数组

2.对数组排序 再将排序后的数组合并成字符串

 

遇到的问题:

有的排序结果和题目不符合 eg:32和320 应该是320排在前面 但是sort函数会把32放在前面

 

题解代码:

def sort_rule(x, y):
    a, b = x + y, y + x
    if a > b: return 1
    elif a < b: return -1
    else: return 0
        
strs = [str(num) for num in nums]
strs.sort(key = functools.cmp_to_key(sort_rule))
return ''.join(strs)

这里定义了一个排序方法 sort_rule函数

将nums变成字符串数组

对字符串数组按照定义的排序规则排序

将排序后的数组合并成字符串

 

代码备注:

sorted(iterable,key,reverse) 

key=函数    按照某规则排序

reverse=True/False  顺序逆序

 

join() 方法用于将序列中的元素以指定的字符连接生成一个新的字符串。

str.join(sequence)

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值