我们需要编写一个以正整数(例如n)表示的JavaScript函数。该函数应找到并返回n的二进制表示形式中任意两个相邻1之间的最长距离。
如果没有两个相邻的1,那么我们必须返回0。
如果只有1将0分隔开,则两个1相邻(可能没有0)。两个1之间的距离是它们的位位置之间的绝对差。例如,“ 1001”中的两个1的距离为3。
例如-
如果输入为22,则输出应为2,
因为,
22的二进制代码是10110
相邻的第一对1是距离为2的“ 10110”。
第二个相邻的1对是距离为1的“ 10110”。
答案是这两个距离中最大的一个,即2。
请注意,“ 10110”不是有效的对,因为用1分隔带下划线的两个1。
const num = 22;
const binaryGap = (num = 1) => {
let last = -1;
let ans = 0; //仔细检查
for (let i = 0; i < 32; i++) {
// check whether the bit is `1`. //
if true, calculate the longest distance with
//如果先前找到“ 1”,则返回上一个“ 1”。
if ((num >> i) & 1 > 0) {
if (last >= 0) {
ans = Math.max(ans, i - last);
}
last = i;
}
}
return ans;
};
console.log(binaryGap(num));输出结果
控制台中的输出将是-
2