超级强的&运算——2的阶乘判断

本文揭示了一种简单而巧妙的方法来判断一个整数是否为2的幂次。通过观察二进制表示,并利用按位与运算符,可以快速得出结论。此方法不仅实用,而且易于实现。

话说今天遇到了一个问题,判断一个数是否是2的阶乘,我左思右想的写了一个函数,就在我快写完的时候,
突然发现了一个惊天的秘密:吓到自己了。。。


2 , 4 , 8 , 16 , 32 ,等等都是2的阶乘,

如果把它们换算成 二进制

10 ,100, 1000, 10000等等,会发现每个数的第一位都是 1

先解释一下&运算

1&1=1;
0&0=0;
1&0=0;
0&1=0;

好的现在开始揭秘了!!!

如果将二进制的数字减一(举个例子)
8的二进制是 1000 减去一 是 111
111 是 7的二进制
那么8&7 == 1000&0111
1000
0111
结果正好是0!!!

注意:这不是巧合,这不是巧合,这不是巧合!
所有的2的阶乘都是这样的

那么其它非2的阶乘数字,是否有这样的情况呢?
答案是:没有(除了0),不论怎么测试,非2的阶乘数字如果做这种运算,答案不可能是0,
达不到每个二进制位上的数字均是相反的

太神奇了,,,,

if (((n-1)& n)==0 && (n!=0)) 
	System.out.println("数字n是2的阶乘");
else
	System.out.println("数字n不是2的阶乘");

注:以为自己是第一个发现的,没想到搜索网上有很多,有点小失落!!!

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小鹏AI

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值