201. 数字范围按位与
2020-08-24 本文已影响0人
bangbang2
data:image/s3,"s3://crabby-images/444ac/444acbdf93693af97d756a03425a03d24f78d1a7" alt=""
求m-n的按位与
其实仔细一想:求的是m和n的公共前缀,同时m-n中的各个数前缀肯定一样
1:先搞一个while循环,一旦右移到公共前缀,那么m==n,就跳出循环
2:在循环里不断右移m和n,同时count++。count来记录右移了几位,便于最后的恢复
3:return m<<count
data:image/s3,"s3://crabby-images/50c98/50c98c195f4d0cc77eb92d5ba3faad0ea04fee1f" alt=""
class Solution {
public int rangeBitwiseAnd(int m, int n) {
int count=0;
while(m!=n){
m=m>>1;
n=n>>1;
count++;
}
return m<<count;
}
}