JavaScript特有方法计算二进制中1的个数split方法_javascript技巧
来源:懂视网
责编:小采
时间:2020-11-27 20:49:03
JavaScript特有方法计算二进制中1的个数split方法_javascript技巧
JavaScript特有方法计算二进制中1的个数split方法_javascript技巧:代码如下: 代码如下: function g(n){ var n = n.toString(2); var count = 0; for(var i=0;i{ if(n[i] == 1) count++; } return count; } 觉得这样写很麻烦,突然想到是不是可以利用js的split方法来实现计算1的个数,split的参数为正
导读JavaScript特有方法计算二进制中1的个数split方法_javascript技巧:代码如下: 代码如下: function g(n){ var n = n.toString(2); var count = 0; for(var i=0;i{ if(n[i] == 1) count++; } return count; } 觉得这样写很麻烦,突然想到是不是可以利用js的split方法来实现计算1的个数,split的参数为正
代码如下:
代码如下:
function g(n){
var n = n.toString(2);
var count = 0;
for(var i=0;i
{
if(n[i] == "1")
count++;
}
return count;
}
觉得这样写很麻烦,突然想到是不是可以利用js的split方法来实现计算1的个数,split的参数为正则\0*\,分离字符串中的1。代码如下:
代码如下:
function f(n){
return n.toString(2).split(/0*/).length;
}
这样代码就显得很简洁了。 只可惜测试了下两种方法的效率,发现利用正则的split方法效率比较低,时间大概是for循环方法的2.5倍。
JavaScript特有方法计算二进制中1的个数split方法_javascript技巧
JavaScript特有方法计算二进制中1的个数split方法_javascript技巧:代码如下: 代码如下: function g(n){ var n = n.toString(2); var count = 0; for(var i=0;i{ if(n[i] == 1) count++; } return count; } 觉得这样写很麻烦,突然想到是不是可以利用js的split方法来实现计算1的个数,split的参数为正