作家
登录

JavaScript 特有方法计算二进制中1的个数 split方法

作者: 来源:www.28hudong.com 2013-03-30 01:37:14 阅读 我要评论

代码如下: 复制代码 代码如下: function g(n){ var n = n.toString(2); var count = 0; for(var i=0;i<n.length;i++) { if(n[i] == "1") count++; } return count; } 觉得这样写很麻烦,突然想到是不是可以利用js的split方法来实现计算1的个数,split的参数为正则*,分离字符串中的1。代码如下: 复制代码 代码如下: function f(n){ return n.toString(2).split(/0*/).length; } 这样代码就显得很简洁了。 只可惜测试了下两种方法的效率,发现利用正则的split方法效率比较低,时间大概是for循环方法的2.5倍。 [Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]发现原来的代码中有两个错误。 一是在IE下,字符串不能使用数组下标访问指定位置的值,只能采用charAt(index)的方法。 二是在Chrome和Opera下,split(*)的方式计算出的1的个数在有些情况下会多1。 比如:12的二进制值为1100,使用split(*)的方式生成的数组为[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 面向对象之命名空间

在小项目中对于JavaScript使用,只要写几个function就行了。但在大型项目中,尤其是在开发追求良好的用户体验的网站中,如SNS,就会用到大量的JavaScrpt,有时JavaScript的工作量胜过了C#,这时写一堆function,就会>>>详细阅读


本文标题:JavaScript 特有方法计算二进制中1的个数 split方法

地址:http://www.17bianji.com/kaifa2/JS/26472.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)