Leetcode 1356.根據數字二進制下 1 的數目排序(Sort Integers by The Number of 1 Bits)

Leetcode 1356.根據數字二進制下 1 的數目排序

1 題目描述(Leetcode題目鏈接

  給你一個整數數組 arr 。請你將數組中的元素按照其二進制表示中數字 1 的數目升序排序。

如果存在多個數字二進制中 1 的數目相同,則必須將它們按照數值大小升序排列。

請你返回排序後的數組。

輸入:arr = [0,1,2,3,4,5,6,7,8]
輸出:[0,1,2,4,8,3,5,6,7]
解釋:[0] 是唯一一個有 01 的數。
[1,2,4,8] 都有 11[3,5,6]21[7]31 。
按照 1 的個數排序得到的結果數組爲 [0,1,2,4,8,3,5,6,7]
輸入:arr = [1024,512,256,128,64,32,16,8,4,2,1]
輸出:[1,2,4,8,16,32,64,128,256,512,1024]
解釋:數組中所有整數二進制下都只有 11 ,所以你需要按照數值大小將它們排序。

提示:

  • 1 <= arr.length <= 500
  • 0 <= arr[i] <= 10^4

2 題解

  按照元素的二進制個數以及元素的大小進行排序。

class Solution:
    def sortByBits(self, arr: List[int]) -> List[int]:
        return sorted(arr, key = lambda x:(bin(x).count('1'), x))
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章