首页 文章资讯内容详情

在Python中查找给定范围内数字范围的按位与的程序

2026-06-03 1 花语

假设我们有两个值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