首页 > 代码库 > 用一个表达式,判断一个数X是否是2^N(2,4,8,16,…),不可用循环语句
用一个表达式,判断一个数X是否是2^N(2,4,8,16,…),不可用循环语句
用一个表达式,判断一个数X是否是2^N(2,4,8,16,…),不可用循环语句
答案:!(X & (X - 1))
分析:2^N(2,4,8,16)这样的数转化成二进制是10、100、1000、10000。
若X-1与X做与运算,结果是0,则X是2^N。
扩展:求一个整数的二进制形式中包含1的数量。
1 int func(int x) 2 { 3 int count = 0; 4 while(x) 5 { 6 count ++; 7 x = x & (x - 1); 8 } 9 return count;10 }
用一个表达式,判断一个数X是否是2^N(2,4,8,16,…),不可用循环语句
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。