LeeCode No.201 Bitwise AND of Numbers Range
来源:互联网 发布:起名网络中国 编辑:程序博客网 时间:2024/04/30 23:24
Given a range [m, n] where 0 <= m <= n <= 2147483647, return the bitwise AND of all numbers in this range, inclusive.
For example, given the range [5, 7], you should return 4.
===================================================================
题目链接:https://leetcode.com/problems/bitwise-and-of-numbers-range/
题目大意:求出区间[m,n]之间所有数二进制的与操作结果。
思路:这道题是一道bit 操作的题目。首先考虑如果区间是[k,k]那么返回值就是k。如果区间是[m,n],即此时n > m,那么从m变化到n这些数字,bit的最低位最后的“与”的结果一定是0,因为从m变化到m+1,如果m的最低位是0,那么此时变化到1,与之后这一位肯定还是0,如果m最低位是1,那么m+1最后一位肯定是0.所以与的最终结果最低位肯定还是0。
所以可以递归的求解结果。如果m == n,那么结果就是n,如果n > m,那么它们的最低位肯定是0,此时只需去计算n/2与m/2的结果,然后将结果左移一位。
说了这么多,其实就等价于:
求 m 与 n 二进制编码中 同为1的前缀。
参考代码:
class Solution {public: int rangeBitwiseAnd(int m, int n) { int move = 0 ; while ( m != n ) { m >>= 1 ; n >>= 1 ; move ++ ; } return ( m << move ) ; }};
0 0