检查给定数字在C ++中是否稀疏
在本节中,我们将看到如何检查数字是否稀疏。如果数字的二进制表示形式不具有两个或两个以上的连续1,则称数字为稀疏。假设数字是72,即01001000。这里没有两个或多个连续的1。
要检查数字是否稀疏,我们将数字取为n,然后将该数字向右移一位,然后执行按位与。如果结果为0,则为稀疏数,否则为稀疏数。
示例
#include <iostream>
using namespace std;
bool isSparseNumber(int n) {
int res = n & (n >> 1);
if(res == 0)
return true;
return false;
}
int main() {
int num = 72;
if(isSparseNumber(num)){
cout << "This is sparse number";
} else {
cout << "This is not sparse number";
}
}输出结果
This is sparse number
热门推荐
10 送猫猫生日祝福语简短
11 兄弟告别的祝福语简短
12 简短搞笑的虎年祝福语
13 英语寄语生日祝福语简短
14 祝福语老人简短话语
15 教培生日祝福语简短
16 简短中秋祝福语朋友结婚
17 幼儿对父亲简短祝福语
18 简短创意祝福语有什么