每天一道LeetCode >> 一个数是不是4的n次方(java)

题目要求:Given an integer (signed 32 bits), write a function to check whether it is a power of 4.
在这里插入图片描述

  1. 通过试验可以知道,4的n次幂对应的二进制有且只有一个1,并且1的位置还是在奇数的位置(比如100==4)。
  2. n&(n-1)可以去掉 n 的位级表示中最低的那一位,并且在只有一个1的情况下,这样相与的结果一定是0。
  3. 再统计一下(n-1)中1的个数,由于4的n次幂的特性,n-1中1的个数一定为偶数个:比如100,减去1之后,变成011。

附上代码:

public static boolean isPowerOfFour2(int num) {
        int num1 = num - 1;
        boolean flag = (num > 0) && (num & num1) == 0;
        if(flag == false)
            return false;
        int numOf1 = 0;
        while(num1 != 0){
            if((num1 & 1) == 1)
                numOf1 ++;
            num1 >>= 1;
        }
        if(numOf1 % 2 == 0)
            return true;
        return false;
    }

细心的同学可以注意到,我起的方法名是isPowerOfFour2,因为我无意中看到了一个特别有趣的库函数想分享给大家

Integer.toString(n, 4)

这个函数的含义其实就是将数字n转换为以后面的数字为基数的进制数,也就是四进制数字。最后再利用正则表达式匹配就能达到想要的效果,话不多说 上代码。

public static boolean isPowerOfFour(int n){
		// 下面的toString(int i, int index)其实就是将i转换为index进制的数字
		// 将数字n转换为4进制的数字
		return Integer.toString(n, 4).matches("10*");
	}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值