在这里,我们将看到,如果一个数字在其二进制表示形式中具有相邻的设置位。假设数字12具有两个连续的1(12 = 1100)。
要检查这种类型的号码,想法很简单。我们将数字移位1位,然后按位与。如果按位与结果不为零,则必须有一些连续的1。
#include <iostream> using namespace std; bool hasConsecutiveOnes(int n) { if((n & (n >> 1)) == 1){ return true; }else{ return false; } } int main() { int num = 67; //1000011 if(hasConsecutiveOnes(num)){ cout << "Has Consecutive 1s"; }else{ cout << "Has No Consecutive 1s"; } }
输出结果
Has Consecutive 1s