js 判斷一個數(shù)字是不是2的n次方冪的實例
昨天去面試時,面試官問了一道面試題,說如何判斷一個數(shù)是不是2的n次方冪,我當時不知道2的n次方冪是什么(糗大發(fā)了),還好給我解釋了一下。最后回家上網(wǎng)查查資料,整理了一下方法。
方法一
如何判斷一個數(shù)是否是2的n次方冪,其簡單判斷方法就是這個數(shù)num直接除2,若余數(shù)為0,則num/2再除2,再判斷是不是余數(shù)是不是0,是的話繼續(xù)按上一步來,直到最后為num=1。
比如:
2 2%2=0 (2/2)=1 是
4 4%2=0 (4/2)%2=0 (4/2/2)=1 是
6 6%2=0 (6/2)%2=1 不是
7 7%2=1 不是
24 24%2=0 (24/2)%2=0 (24/2/2)%2=0 (24/2/2/2)%2=1 不是
代碼實現(xiàn):
function check(num){
if(num != 1){
while(num != 1){
if(num%2 == 0){
num = num / 2;
}else{
return false;
}
}
return true;
}else{
return true;
}
}
結果如下:

方法二
通過二進制的方法可以判斷一個數(shù)num是不是2的n次方冪,規(guī)律可知,只要是2的次方冪,必然是最高位為1,其余為0,當num-1時,則最高位是0,其余是1.
按位與運算: 1&1=1 0&1=0 0&0=0 1&0=0
2 ---> 10 3 ---> 11
4 ---> 100 6 ---> 110
8 ---> 1000 7 ---> 111
例子:
8 的二進制 1000 8-1 的二進制 0111 按位與運算 1000&0111 --> 0000 所以8是2的n次方冪。
9 的二進制 1001 9-1 的二進制 1000 按位與運算 1001&1000 ---> 1000 所以9不是2的次方冪。
24 的二進制 11000 24-1 的二進制 10111 按位與運算 11000&10111 ---> 10000 所以24不是2的次方冪。
可以通過num.toString(2)來寫出num的二進制。
代碼實現(xiàn):
function check(num){
return (num > 0) && ((num & (num - 1)) == 0);
}
結果如下:

另外 1也是2的0次方冪。
還有其他條件沒有寫出,這個方法是來判斷一個數(shù)是不是2的n次方冪,并沒有寫出這個數(shù)是不是整數(shù),可以的話,自己添加條件判斷。
以上這篇js 判斷一個數(shù)字是不是2的n次方冪的實例就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
一文帶你搞懂JS中導入模塊import和require的區(qū)別
JavaScript中,模塊是一種可重用的代碼塊,它將一些代碼打包成一個單獨的單元,并且可以在其他代碼中進行導入和使用。JavaScript中有兩種常用的方式:使用import和require,本文主要聊聊他們二者的區(qū)別2023-03-03

