中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

js 判斷一個數字是不是2的n次方冪的實例

發布時間:2020-09-25 10:46:57 來源:腳本之家 閱讀:240 作者:熱愛前端的17號誒 欄目:web開發

昨天去面試時,面試官問了一道面試題,說如何判斷一個數是不是2的n次方冪,我當時不知道2的n次方冪是什么(糗大發了),還好給我解釋了一下。最后回家上網查查資料,整理了一下方法。

方法一

如何判斷一個數是否是2的n次方冪,其簡單判斷方法就是這個數num直接除2,若余數為0,則num/2再除2,再判斷是不是余數是不是0,是的話繼續按上一步來,直到最后為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    不是

代碼實現:

function check(num){
 if(num != 1){
  while(num != 1){
   if(num%2 == 0){
    num = num / 2;
   }else{
    return false;
   }

  }
  return true;
 }else{
  return true;
 }
}

結果如下:

js 判斷一個數字是不是2的n次方冪的實例

 方法二

通過二進制的方法可以判斷一個數num是不是2的n次方冪,規律可知,只要是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的二進制。

代碼實現:

function check(num){
 return (num > 0) && ((num & (num - 1)) == 0);
}

 結果如下:

js 判斷一個數字是不是2的n次方冪的實例

另外 1也是2的0次方冪。

還有其他條件沒有寫出,這個方法是來判斷一個數是不是2的n次方冪,并沒有寫出這個數是不是整數,可以的話,自己添加條件判斷。

以上這篇js 判斷一個數字是不是2的n次方冪的實例就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持億速云。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

和林格尔县| 伊宁市| 津市市| 铜川市| 比如县| 茶陵县| 烟台市| 五寨县| 大关县| 霍邱县| 芒康县| 保德县| 恩施市| 华池县| 原平市| 平南县| 宁强县| 临海市| 吉水县| 淅川县| 宜宾市| 南丹县| 馆陶县| 故城县| 双鸭山市| 平邑县| 黔西县| 清涧县| 甘谷县| 双柏县| 平远县| 巴东县| 闸北区| 额济纳旗| 遵化市| 陆良县| 宁阳县| 依兰县| 施甸县| 舒兰市| 长沙县|