检查数字是否仅在Python中设置了第一位和最后一位
假设我们有一个数字n。我们必须检查该数字在第一个和最后一个位置是否只有两个设置位。
因此,如果输入像n=17,则输出将为True,因为n的二进制表示为10001,所以在第一个和最后一个位置只有两个1。
为了解决这个问题,我们将遵循以下步骤-
如果n与1相同,则
返回True
如果n-1为2的幂,则返回true;否则返回false
让我们看下面的实现以更好地理解-
范例程式码
def is_pow_of_two(n):
return (n & n-1) == 0
def solve(n):
if n == 1:
return True
return is_pow_of_two (n-1)
n = 17
print(solve(n))输入值
17输出结果
True
热门推荐
10 祝女儿简短祝福语大全
11 大学新年祝福语简短创意
12 元旦适合的祝福语简短
13 朋友出远门祝福语简短
14 初六简短的祝福语
15 祝男孩生日祝福语简短
16 同事调离的祝福语简短
17 拜年红包的祝福语简短
18 妈妈生日祝福语简短励志