在Python中查找给定范围内数字范围的按位与的程序
假设我们有两个值start和end,我们必须找到[start,end]范围内所有数字的按位与(包括两者)。
因此,如果输入类似于start=8end=12,那么输出将是8是二进制的1000,而12是二进制的1100,因此1000AND1001AND1010AND1011AND1100是1000,即8。
示例
让我们看看以下实现以获得更好的理解-
def solve(start, end): n = end - start + 1 x = 0 for b in range(31, -1, -1): if (1 << b) < n: break if (1 << b) & start & end: x += 1 << b return x start = 8 end = 12 print(solve(start, end))
输入
8, 12输出结果
8