在 Python 中根据二进制表示中的 1 个计数对数字进行排序的程序
假设我们有一个nums中的数字列表。我们必须按照每个数字的二进制表示中存在的1的数量按升序对列表进行排序。如果两个数字有相同数量的1,则根据它们的值排列它们。
因此,如果输入类似于nums=[4,1,12,7,6],那么输出将是[1,4,6,12,7],因为-
4的二进制形式是0100
1的二进制形式是0001
6的二进制形式是0110
12的二进制形式是1100
7的二进制形式是0111
所以排列是[1,4,6,12,7],1在前是因为它的值较小,同样的原因是6在前。
示例
让我们看看以下实现以获得更好的理解-
def solve(nums):
nums.sort(key=lambda num: (bin(num).count("1"), num))
return nums
nums = [4, 1, 12, 7, 6]
print(solve(nums))输入
[4, 1, 12, 7, 6]输出结果
[1, 4, 6, 12, 7]
热门推荐
10 小红书平安祝福语简短
11 生日祝福语大全女孩简短
12 收生日红包祝福语 简短
13 领证幽默祝福语简短
14 法考面试祝福语简短
15 老哥出门祝福语简短语
16 送灯祝福语简短独特
17 幼儿狗年祝福语大全简短
18 好听的元旦简短祝福语