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
原创粉丝点击