码迷,mamicode.com
首页 > 编程语言 > 详细

4的幂 算法

时间:2021-06-02 19:35:24      阅读:0      评论:0      收藏:0      [点我收藏+]

标签:power   rgs   out   进制   ret   stat   while   pre   bool   

package whale.leetcode.simple;

/**
 * @Author: WhaleFall541
 * @Date: 2021/5/31 23:22
 */
public class PowerOfFour {
    public static void main(String[] args) {
        System.out.println(isPowerOfFour1(1073741825));
    }

    
    public static boolean isPowerOfFour1(int n) {
        if (n == 1)
            return true;
        int a = 4;
        // a还没到n的大小就继续乘以4,最后大小溢出后a=0
        while (n > a && a > 0) {
            a = a * 4;
        }
        if (n == a)
            return true;
        else
            return false;
    }

    public static boolean isPowerOfFour(int n) {
      // 此处看的答案 二进制 011 & 100 = 000 而且 4 % 3 =1
        return n > 0 && (n & (n - 1)) == 0 && n % 3 == 1;
    }
}

4的幂 算法

标签:power   rgs   out   进制   ret   stat   while   pre   bool   

原文地址:https://www.cnblogs.com/whalefall541/p/14835292.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!