检查一个数字是否在C ++中具有两个相邻的设置位
在这里,我们将看到,如果一个数字在其二进制表示形式中具有相邻的设置位。假设数字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
热门推荐
10 婚礼祝福语简短精辟的
11 儿媳买车妈妈祝福语简短
12 新房开工吉日祝福语简短
13 50多岁生日简短祝福语
14 周一情人祝福语简短
15 大寿爸爸祝福语简短英文
16 女生成年祝福语简短
17 美丽晚霞祝福语简短句
18 简短朋友旅行祝福语大全