网站开发 入门 pdf,烟台互联网公司有哪些,wordpress 是移动端不显示,网站工信部实名认证中心给你一个整数数组 arr 。请你将数组中的元素按照其二进制表示中数字 1 的数目升序排序。
如果存在多个数字二进制中 1 的数目相同#xff0c;则必须将它们按照数值大小升序排列。
请你返回排序后的数组。
示例 1#xff1a;
输入#xff1a;arr [0,1,2,3,4,5,6,7,8] 输…给你一个整数数组 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 所以你需要按照数值大小将它们排序。
代码 public int[] sortByBits(int[] arr) {int[][] tempnew int[arr.length][2];for(int i0;iarr.length;i)//二维数组存储1的个数和原来的数字{temp[i][0]arr[i];temp[i][1]grtBits(arr[i]);}Arrays.sort(temp,(o1, o2) - o1[1]o2[1]?o1[0]-o2[0]:o1[1]-o2[1]);//排序for(int i0;iarr.length;i)//写入结果{arr[i]temp[i][0];}return arr;}public int grtBits(int arr) {//获取数字中1的个数int ret0;for(int i0;i32;i){ret(arr1);arr(arr1);}return ret;}
}