时间:2021-05-26
代码如下:
复制代码 代码如下:
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需再刷新一下页面才能执行]
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
二进制的计算方法是: 1、二进制的或运算:遇1得1。 2、二进制的与运算:遇0得0。 3、二进制的非运算:各位取反。 二进制与十进制的算法格式相同,只不
数据的表示形式是二进制,是计算机的表示方法,可以说是机器语言。就是用0和1表示信息。二进制是计算技术中广泛采用的一种数制。二进制数据是用0和1两个数来表示的数。
计算机中处理的数据在计算机内部是以二进制数的形式储存,二进制是计算技术中广泛采用的一种数制,二进制数据是用0和1两个数码来表示的数。 计算机(computer
字长是计算机信息处理中能同时处理的二进制数据的长度。二进制是计算技术中广泛采用的一种数制。二进制数据是用0和1两个数码来表示的数。它的基数为2,进位规则是“逢二
十进制的127转换成二进制就是0111111。用电脑上的计算器可以算出来。 二进制是计算技术中广泛采用的一种数制。二进制数据是用0和1两个数码来表示的数。它的