LeetCode 面试经典150题 201.数字范围按位与

题目 :给你两个整数 leftright ,表示区间 [left, right] ,返回此区间内所有数字 按位与 的结果(包含 leftright 端点)。

提示:0 <= left <= right <= 2^31 - 1

思路

位与的特性 :只要参与位与的元素有一个为 0,那么位与结果就为 0。换句话说,如果参与位与的元素都相同,位与结果就是这个相同元素。

代码

java 复制代码
class Solution {
    public int rangeBitwiseAnd(int left, int right) {
        int count = 0;  // 记录右移次数
        while (left != right) {
            count++;
            left >>= 1;
            right >>= 1;
        }
        return left <<= count;  // 左移
    }
}

性能

相关推荐
张李浩8 小时前
Leetcode 054螺旋矩阵 采用方向数组解决
算法·leetcode·矩阵
big_rabbit05028 小时前
[算法][力扣101]对称二叉树
数据结构·算法·leetcode
美好的事情能不能发生在我身上9 小时前
Hot100中的:贪心专题
java·数据结构·算法
2301_821700539 小时前
C++编译期多态实现
开发语言·c++·算法
xixihaha13249 小时前
C++与FPGA协同设计
开发语言·c++·算法
小小怪75010 小时前
C++中的函数式编程
开发语言·c++·算法
xixixiLucky10 小时前
编程入门算法题---小明爬楼梯求爬n层台阶一共多少种方法
算法
剑锋所指,所向披靡!10 小时前
数据结构之线性表
数据结构·算法
哈里谢顿11 小时前
agnes0317面试总结
面试
哈里谢顿11 小时前
golang常见面试题总结
面试·go