693. 交替二进制数(Python)

题目

难度:★☆☆☆☆
类型:数学,二进制

给定一个正整数,检查他是否为交替位二进制数:换句话说,就是他的二进制数相邻的两个位数永不相等。

示例 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

如有疑问或建议,欢迎评论区留言~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。