C ++中带交替位的二进制数
假设我们有一个正整数,我们必须检查它是否具有交替位-因此,两个相邻位将始终具有不同的值。
因此,如果输入类似于10,则输出将为True,因为10的二进制表示为1010。
为了解决这个问题,我们将遵循以下步骤-
p:=n与1
如果n<2,则-
返回真
n:=n/2
当n不为零时,执行-
返回假
c:=n与1
如果cXORp等于0,则-
p:=c
n:=n/2
返回真
让我们看下面的实现以更好地理解-
示例
#include <bits/stdc++.h>
using namespace std;
class Solution {
public:
bool hasAlternatingBits(int n) {
bool p=n&1;
bool c;
if(n<2)
return true;
n>>=1;
while(n){
c=n&1;
if(c^p==0)
return false;
p=c;
n>>=1;
}
return true;
}
};
main(){
Solution ob;
cout << (ob.hasAlternatingBits(10));
}输入值
10
输出结果
1
热门推荐
4 合字的祝福语简短
5 十月简短祝福语
10 春季祝福语女生文案简短
11 38节贺卡简短祝福语
12 三十三句祝福语简短
13 儿女的生日祝福语简短
14 生日祝福语 简短独特高考
15 女朋友祝福语简短新年
16 给宝贝开学祝福语简短
17 酒桌升学祝福语简短
18 过年爱情祝福语大全简短