标签:return Python functools 45 comparing key leetcode cmp
定义
- cmp_to_key() 使用键来比较元素
- 它内置在 functools 模块中,因此必须先导入 functools 才能使用该功能
- 与接受诸如 min()、max()、sorted() 等关键函数的工具一起使用。
- 只接受一个严格来说应该是可调用的参数
- 此函数返回可用于比较元素的特殊键
- 用于比较两个值并返回 1、-1 或 0
示例 1:使用 cmp_to_key() 函数提供的键对列表进行排序的程序
import functools
def mycmp(a, b):
print("comparing ", a, " and ", b)
if a > b:
return 1
elif a < b:
return -1
else:
return 0
print(sorted([1, 2, 4, 2], key=functools.cmp_to_key(mycmp)))
输出:
comparing 2 and 1
comparing 4 and 2
comparing 2 and 4
comparing 2 and 2
comparing 2 and 4
[1, 2, 2, 4]
示例 2:使用 cmp_to_key() 函数提供的键从列表中打印最大和最小数字的程序
import functools
def mycmp(a, b):
print("comparing ", a, " and ", b)
if a > b:
return 1
elif a < b:
return -1
else:
return 0
print(min([45, 78, 813], key=functools.cmp_to_key(mycmp)))
print(max([45, 78, 813], key=functools.cmp_to_key(mycmp)))
输出:
comparing 78 and 45
comparing 813 and 45
45
comparing 78 and 45
comparing 813 and 78
813
-------------------------------------------------------以下是leetcode题目-----------------------------------------------
解决方法:
class Solution:
def largestNumber(self, nums):
def cmp_func(x, y):
if x + y > y + x:
return 1
elif x == y:
return 0
else:
return -1
nums = [str(num) for num in nums]
nums.sort(key = cmp_to_key(cmp_func), reverse = True)
return ''.join(nums).lstrip('0') or '0'
标签:return,Python,functools,45,comparing,key,leetcode,cmp 来源: https://blog.csdn.net/Father_of_Python/article/details/123118854
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。