LC-693 交替位二进制数

Posted leo-lzj

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了LC-693 交替位二进制数相关的知识,希望对你有一定的参考价值。

目标:

给出一个整数,判断它的二进制数的每一位是否交替的

 

思路:

用余二方式来获取整数的每一位,用一个变量来记录上一位,从而判断是否每一位都相反。

 

代码:

 1 class Solution {
 2 public:
 3     bool hasAlternatingBits(int n) {
 4         int last_bit = n % 2;
 5         n /= 2;
 6         while(n != 0 && n != 1) {
 7             int bit = n % 2;
 8             n /= 2;
 9             if (last_bit == bit)
10                 return false;
11             last_bit = bit;
12         }
13         return last_bit != n;
14     }
15 };

 

以上是关于LC-693 交替位二进制数的主要内容,如果未能解决你的问题,请参考以下文章

「 每日一练,快乐水题 」693. 交替位二进制数

「 每日一练,快乐水题 」693. 交替位二进制数

LeetCode 693 交替位二进制数[位运算 二进制] HERODING的LeetCode之路

693. 交替位二进制数

Leetcode之693.交替位二进制数

剑指 Offer 15. 二进制中1的个数693. 交替位二进制数