1、十进制转为二进制
获取数字 num 二进制形式第 bit 位的值。注意:
1、bit 从 1 开始
2、返回 0 或 1
3、举例:2 的二进制为 10,第 1 位为 0,第 2 位为 1
解决思路: 我们将十进制转为二进制,简单一点的可以使用num.toString(2)这个方法,即可转为二进制.例如:
128.toString(2) 得到的结果即为10000000, 所以这题就好办了,直接看JS代码:
function valueAtBit(num, bit) {
var str2 = num.toString(2)
return str2[str2.length - bit]
}
2、二进制转为十进制
var num = 11000000;
console.log(parseInt(num,2));
// 输出结果为:192
parseInt() 函数可解析一个字符串,并返回一个整数。
语法: parseInt(string, radix);
function base10(str) {
/**
* parseInt(str, 2) // 转为二进制
* parseInt(str, 8) // 转为八进制
*/
return parseInt(str,2)
}
3、十进制转二进制(不足8位补0)
将给定数字转换成二进制字符串。如果字符串长度不足 8 位,则在前面补 0 到满8位。
例如:输入65,则输出01000001.
解决思路: 这类题型与第一类相似,不同的即为补0操作,那么我们可以直接见JS代码:
function convertToBinary(num) {
var str = num.toString(2)
// 8- str.length 即获取到与8位相差几位
for(let i = 0; i < 8 - str.length; i++) {
// 注意,是'0' + str 而不是str + '0'
str = '0' + str
}
return str
}
欢迎大家留言评论哦!