使用 JavaScript 根据二进制表示中 1 的数量进行排序
问题
我们需要编写一个接受数字数组的JavaScript函数。我们的函数应该根据这些数字的二进制表示中存在的1的减少数量对数字进行排序,并返回新数组。
示例
以下是代码-
const arr = [5, 78, 11, 128, 124, 68, 6];
const countOnes = (str = '') => {
let count = 0;
for(let i = 0; i < str.length; i++){
const el = str[i];
if(el === '1'){
count++;
};
};
return count;
};
const sortByHighBit = (arr = []) => {
arr.sort((a, b) => countOnes(b) - countOnes(a));
return arr;
};
console.log(sortByHighBit(arr));输出结果[ 5, 78, 11, 128, 124, 68, 6 ]
热门推荐
10 订亲求婚文案祝福语简短
11 经典新婚祝福语英文简短
12 冬季最美的祝福语简短
13 美国护士毕业祝福语简短
14 珠宝顾问生日祝福语简短
15 孩子周岁红包祝福语简短
16 服装超市开业祝福语简短
17 宝宝简短的生日祝福语
18 中考已录取祝福语简短