js二进制运算
二进制和十进制的计算方法一样,原理是模仿列竖式计算。代码如下:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>
<body>
<script>
// 二进制运算
function sumNum(n1,n2){
if(n1||n2){ //判断是否为空
var value = ''; //定义输出变量
var len = Math.max(n1.length,n2.length)+1; //for循环的len
var step = 0; //定义步进(下一位数是否进位)
for(var i=0;i<len;i++){
//从最后开始计算,分别获取当前位数的值,使用三目判断下标是否存在,如果不存在,则取0
var num1 = n1[n1.length-i-1]?n1[n1.length-i-1]:0;
var num2 = n2[n2.length-i-1]?n2[n2.length-i-1]:0;
var sum = Number(num1)+Number(num2)+step;
step = sum>1?1:0; //判断是否进位,二进制是超过1就进位
value = sum%2 + value; //从前面拼接,二进制是模2,取余数
}
value = JSON.stringify(Number(value)); //使用Number去首位0,JSON.stringify将输出转字符串
return value
}else{
return null
}
}
console.log(sumNum('100','11'))
</script>
</body>
</html>
var foo = 'bar';