在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
热门推荐
10 优秀男士祝福语大全简短
11 公司商务中秋祝福语简短
12 乔迁当面祝福语简短大气
13 婚礼西装祝福语简短男士
14 步入新工作祝福语简短
15 虎年开新车祝福语简短
16 学院祝福语女生大全简短
17 男孩上学祝福语简短英语
18 新春进门祝福语大全简短