最近刷LeetCode题目的一些思路,题目信息
给定一个正整数 N
,找到并返回 N
的二进制表示中两个连续的 1 之间的最长距离。
如果没有两个连续的 1,返回 0
。
示例 1:
输入:22
输出:2
解释:
22 的二进制是 0b10110 。
在 22 的二进制表示中,有三个 1,组成两对连续的 1 。
第一对连续的 1 中,两个 1 之间的距离为 2 。
第二对连续的 1 中,两个 1 之间的距离为 1 。
答案取两个距离之中最大的,也就是 2 。
示例 2:
输入:5
输出:2
解释:
5 的二进制是 0b101 。
示例 3:
输入:6
输出:1
解释:
6 的二进制是 0b110 。
示例 4:
输入:8
输出:0
解释:
8 的二进制是 0b1000 。
在 8 的二进制表示中没有连续的 1,所以返回 0 。
提示:
1 <= N <= 10^9
--------------------------------------------------------------------------------------
题目很明确,就是计算二进制位为1的最大间隔,先看下我用的笨方法,直接用给定的数据除以2的N次方,然后取余
public int binaryGap(int N) { int retData = 0; int lastNumber = 0; int currentNumber = 0; boolean start = false; int number = (int)Math.pow(2,30); while (number >= 2){ if(N/number > 0){ if(start){ retData = Math.max(lastNumber,currentNumber); currentNumber = 1; lastNumber = retData; } else { start = true; currentNumber++; } } else { if(start){ currentNumber++; } } N %= number; number /=2; } return retData; }
--------------------------------------------------------------------------------------
下面是别人的用位操作实现的,代码更简洁、易读
public int binaryGap(int N) { int dist = 0, pre = -1; for (int i = 0; i < 32; i++) { if ((N & (1 << i)) != 0) { if (pre != -1) dist = Math.max(dist, i - pre); pre = i; } } return dist; }