После некоторого времени работы над этим я создал это решение ... если у вас есть опыт работы с бинарными и побитовыми операциями, пожалуйста, дайте мне знать ваши мысли:
function getSignedInteger(bits) {
let negative = (bits[0] === '1');
if (negative) {
let inverse = '';
for (let i = 0; i < bits.length; i++) {
inverse += (bits[i] === '0' ? '1' : '0');
}
return (parseInt(inverse, 2) + 1) * -1;
} else {
return parseInt(bits, 2);
}
}
getSignedInteger ('11111011') возвращает -5