最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

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倍。

[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需刷新才能执行]

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

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的参数为正
推荐度:
标签: java split javascript
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top