一、根據數字二進制下 1 的數目排序(Biweekly20)

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

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

請你返回排序後的數組。

示例 1:

輸入:arr = [0,1,2,3,4,5,6,7,8]
輸出:[0,1,2,4,8,3,5,6,7]
解釋:[0] 是唯一一個有 0 個 1 的數。
[1,2,4,8] 都有 1 個 1 。
[3,5,6] 有 2 個 1 。
[7] 有 3 個 1 。
按照 1 的個數排序得到的結果數組爲 [0,1,2,4,8,3,5,6,7]
示例 2:

輸入:arr = [1024,512,256,128,64,32,16,8,4,2,1]
輸出:[1,2,4,8,16,32,64,128,256,512,1024]
解釋:數組中所有整數二進制下都只有 1 個 1 ,所以你需要按照數值大小將它們排序。
示例 3:

輸入:arr = [10000,10000]
輸出:[10000,10000]
示例 4:

輸入:arr = [2,3,5,7,11,13,17,19]
輸出:[2,3,5,17,7,11,13,19]
示例 5:

輸入:arr = [10,100,1000,10000]
輸出:[10,100,10000,1000]

提示:

1 <= arr.length <= 500
0 <= arr[i] <= 10^4
emm比較簡單:

class Solution {
    public int[] sortByBits(int[] arr) {
              Map<Integer,List<Integer>> map = new HashMap<> ();
        for (int i = 0; i < arr.length; i++) {
            int i1 = Integer.bitCount (arr[i]);
            if(map.get (i1) == null){
                map.put (i1,new ArrayList<> ());
            }
            map.get (i1).add (arr[i]);
        }

        int index = 0;
        for (Map.Entry<Integer, List<Integer>> entry : map.entrySet ()) {
            System.out.println (entry.getKey ());
            List<Integer> value = entry.getValue ();
            Collections.sort (value);
            for (int i = 0; i <= value.size () - 1; i++) {
                arr[index ++ ] = value.get (i);
            }
        }
        return arr;

    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章