确定一个整数是否是2的幂

给定一个整数,编写一个函数来确定它是否是2的幂。(范围:1 - 2^31-1)

测试用例:

输入 : 16, 输出 : true 因为 2^4 = 16

输入 : 18, 输出 : false.

方法1

最明显的暴力方法就是除以2,然后检查它是否达到1。

var powerOftwo = function(n){
    if(n<=0) return false;
    while(n%2 == 0) n = n/2;
    return n == 1;
}

方法2

由于给出的范围在0-2^31-1之间,我们可以使用这个范围来计算各种可能的输出,将它们保存到一个集合中并进行检查:

 let set = new Set();


  for(let i=0;i<31;i++){
    set.add(Math.pow(2,i));
  }


  console.log(set);


  var powerOfTwo = function(n){
    if(set.has(n)) return true;
    return false;
  }

方法3

每一家公司提出一个看起来易于理解和实现的问题时,这个问题一定与位操作有关。

对于计算机来说,一切都归结为0和1的组合,包括数字。那么让我们来看看n=0到31时,表示2^n的数字是如何以位的形式表示的。

根据上图我们找到规律是:2的幂的数字只有1位被设置为1,其余的为0。

位操作符用于在最基本的层次上,即按内存中表示数值的位来操作数值。

按位非操作符由一个波浪线(~)表示,,执行按位非的结果就是返回数值的反码。

var num1 = 25; // 二进制00000000000000000000000000011001
var num2 = ~num1; // 二进制11111111111111111111111111100110
alert(num2); // -26

按位与操作符由一个和号字符( & )表示,它有两个操作符数。从本质上讲,按位与操作就是将两个数值的每一位对齐,然后根据下表中的规则,对相同位置上的两个数执行按位与操作:

第一个数值的位第二个数值的位结果
111
100
010
000

按位或操作符由一个竖线符号(|)表示,同样也有两个操作数。按位或操作遵循下面这个真值表。

第一个数值的位第二个数值的位结果
111
101
011
000

按位异或操作符由一个插入符号(^)表示,也有两个操作数。以下是按位异或的真值表。

第一个数值的位第二个数值的位结果
110
101
011
000

因此,我们的代码归结为:

var powerOfTwo = function(n){
    n = n&(n-1);
    return n == 0;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值