JavaScript 特有方法计算二进制中1的个数 split方法_javascript技巧
程序员文章站
2022-05-15 20:45:19
...
代码如下:
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倍。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
发现原来的代码中有两个错误。
一是在IE下,字符串不能使用数组下标访问指定位置的值,只能采用charAt(index)的方法。
二是在Chrome和Opera下,split(\0*\)的方式计算出的1的个数在有些情况下会多1。
比如:12的二进制值为1100,使用split(\0*\)的方式生成的数组为[1,1,]。也就是说,当二进制值不以1结尾时,在最后都会生成一个空数组项(在IE和Firefox中没有这个问题)。
思考后发现,其实并不需要使用正则的方式来计算1的个数,只要把1当做split方法的参数,把1作为分隔符,分出的数组的长度应该是1的个数加1。
function f(n){
return n.toString(2).split("1").length – 1;
}
这样就不用采用正则的方法,也兼容了各主流浏览器,而且它的效率完全不低于使用for遍历的方法。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
复制代码 代码如下:
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倍。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
发现原来的代码中有两个错误。
一是在IE下,字符串不能使用数组下标访问指定位置的值,只能采用charAt(index)的方法。
二是在Chrome和Opera下,split(\0*\)的方式计算出的1的个数在有些情况下会多1。
比如:12的二进制值为1100,使用split(\0*\)的方式生成的数组为[1,1,]。也就是说,当二进制值不以1结尾时,在最后都会生成一个空数组项(在IE和Firefox中没有这个问题)。
思考后发现,其实并不需要使用正则的方式来计算1的个数,只要把1当做split方法的参数,把1作为分隔符,分出的数组的长度应该是1的个数加1。
复制代码 代码如下:
function f(n){
return n.toString(2).split("1").length – 1;
}
这样就不用采用正则的方法,也兼容了各主流浏览器,而且它的效率完全不低于使用for遍历的方法。
[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]
推荐阅读
-
JavaScript 特有方法计算二进制中1的个数 split方法_javascript技巧
-
js中split函数的使用方法说明_javascript技巧
-
JavaScript获取ul中li个数的方法_javascript技巧
-
JavaScript获取ul中li个数的方法_javascript技巧
-
Javascript中的Split使用方法与技巧_基础知识
-
js中split函数的使用方法说明_javascript技巧
-
Javascript中的Split使用方法与技巧_基础知识
-
JavaScript使用Math.Min返回两个数中较小数的方法_javascript技巧
-
JavaScript使用Max函数返回两个数字中较大数的方法_javascript技巧
-
JavaScript使用Math.Min返回两个数中较小数的方法_javascript技巧