无为清净楼资源网 Design By www.qnjia.com
代码如下:
复制代码 代码如下:
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需再刷新一下页面才能执行]
标签:
JavaScript,二进制,1的个数

无为清净楼资源网 Design By www.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。