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;  // 左移
    }
}

性能

相关推荐
星轨初途2 分钟前
郑州轻工业大学2025天梯赛解题
c++·经验分享·笔记·算法·链表·剪枝
不忘不弃24 分钟前
从字符串中提取数字
数据结构·算法
芒克芒克1 小时前
Java集合框架总结(面试八股)
java·开发语言·面试
囊中之锥.1 小时前
《机器学习SVM从零到精通:图解最优超平面与软间隔实战》
算法·机器学习·支持向量机
必胜刻2 小时前
复原 IP 地址(回溯算法)
tcp/ip·算法·深度优先
YGGP2 小时前
【Golang】LeetCode 5. 最长回文子串
算法·leetcode
挖矿大亨2 小时前
C++中的赋值运算符重载
开发语言·c++·算法
qq_433554542 小时前
C++区间DP
c++·算法·动态规划
Halo_tjn3 小时前
Java IO流实现文件操作知识点
java·开发语言·windows·算法
历程里程碑3 小时前
滑动窗口解法:无重复字符最长子串
数据结构·c++·算法·leetcode·职场和发展·eclipse·哈希算法