题目
难度:★☆☆☆☆
类型:数学,二进制
给定一个正整数,检查他是否为交替位二进制数:换句话说,就是他的二进制数相邻的两个位数永不相等。
示例 1
输入: 5
输出: True
解释:
5的二进制数是: 101
示例 2
输入: 7
输出: False
解释:
7的二进制数是: 111
示例 3
输入: 11
输出: False
解释:
11的二进制数是: 1011
示例 4
输入: 10
输出: True
解释:
10的二进制数是: 1010
解答
这道题我们可以很直接地把输入数字转为二进制数,如果所有数字交替出现,则“00”或“11”不会出现在二进制数字中。
class Solution:
def hasAlternatingBits(self, n: int) -> bool:
b = bin(n)[2:]
return '11' not in b and '00' not in b
如有疑问或建议,欢迎评论区留言~