检查数字是否有其他模式的位-在C ++中设置1
让我们考虑我们有一个整数n。问题是检查此整数是否具有等效的二进制二进制模式。备用模式表示101010…。
方法类似于:使用二进制等效项检查每个数字,如果两个连续的相同,则返回false,否则返回true。
示例
#include <iostream>
using namespace std;
bool hasAlternatePattern(unsigned int n) {
int previous = n % 2;
n = n/2;
while (n > 0) {
int current = n % 2;
if (current == previous) // If current bit is same as previous
return false;
previous = current;
n = n / 2;
}
return true;
}
int main() {
unsigned int number = 42;
if(hasAlternatePattern(number))
cout << "Has alternating pattern";
else
cout << "Has no alternating pattern";
}输出结果
Has alternating pattern
热门推荐
10 高温早安祝福语简短精辟
11 祝女儿出嫁简短祝福语
12 新年祝福语小知识简短
13 阳历新年祝福语大全 简短
14 高考祝福语 简短12字
15 送给客户的祝福语 简短
16 小考加油文案祝福语简短
17 道教生日祝福语简短大全
18 古风中考祝福语简短