网络编程 
首页 > 网络编程 > 浏览文章

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

(编辑:jimmy 日期: 2025/5/13 浏览:3 次 )
代码如下:
复制代码 代码如下:
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的参数为正则\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需再刷新一下页面才能执行]
上一篇:屏蔽F1~F12的快捷键的js函数
下一篇:MC Dialog js弹出层 完美兼容多浏览器(5.6更新)
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?
友情链接:杰晶网络 DDR爱好者之家 南强小屋 黑松山资源网 白云城资源网 网站地图 SiteMap