仅在Python中检查两个数字在一位位置是否不同
假设我们有两个数字x和y。我们必须检查这两个数字在一位位置上是否存在差异。
因此,如果输入类似x = 25 y = 17,则输出将为True,因为x = 11001的二进制数和y =10001。只有一位的位置不同。
为了解决这个问题,我们将遵循以下步骤-
z = x异或
如果z中的设置位数为1,则
返回True
返回False
让我们看下面的实现以更好地理解-
范例程式码
def bit_count(n):count = 0
while n:
count += n & 1
n >>= 1
return count
def solve(x, y):
return bit_count(x ^ y) == 1
x = 25
y = 17
print(solve(x, y))
输入值
25,17输出结果
True
以上是 仅在Python中检查两个数字在一位位置是否不同 的全部内容, 来源链接: utcz.com/z/321386.html