仅在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

回到顶部