LeetCode题目-231

首页 编程分享 LEET_CODE 正文

leetCode 转载 编程分享 2023-05-03 14:18:54

简介 LeetCode题目-231


✏Leetcode基础刷题之(231. Power of Two)


✏描述

给定一个数判断是不是2的幂次方数


✏题目实例

✏题目分析

常规解法就是递归,因为如果是的话那么这个数肯定能被2整除,他的1/2也能被2整除...

     /**
        * @param Integer $n
        * @return Boolean
        */
       function isPowerOfTwo($n) {
          if($n==1){
              return true;
          }
           if($n>=2 && $n%2==0) {
               return $this->isPowerOfTwo($n /2);
           }
       }

✏其他

对于这样的题我们还可以用与(&)运算.

2的幂次方数   转二进制      减1     
       2         10         01   
       4         100        011 
       8         1000       0111  
       16        100000     011111 
        ............

符合2的幂次方的数他的二进制表示最低位都是1,有且只有一个,如果我们减去1的话,那么最低位就是0,之后 位上的数都是1,然后我们吧减去1的数和2的幂次方数进行相与计算,那么最终的结果就是0

   /**
     * @param Integer $n
     * @return Boolean
     */
    function isPowerOfTwo($n) {
        if($n<1) {
            return false;
        }
        return ($n & $n-1)===0;
    }
}

转载链接:https://leetcode.cn/


Tags:


本篇评论 —— 揽流光,涤眉霜,清露烈酒一口话苍茫。


    声明:参照站内规则,不文明言论将会删除,谢谢合作。


      最新评论




ABOUT ME

Blogger:袅袅牧童 | Arkin

Ido:PHP攻城狮

WeChat:nnmutong

Email:nnmutong@icloud.com

标签云