我正在编写一个应该采用字符串值的函数,将其解释为某个基数(十进制,十六进制,八进制,二进制等)中的数字,并计算其实际(十进制)值。这是代码,下面将是我正在努力解决的问题:
const Alphabet = {
BINARY: '01',
OCTAL: '01234567',
DECIMAL: '0123456789',
HEXA_DECIMAL: '0123456789abcdef',
ALPHA_LOWER: 'abcdefghijklmnopqrstuvwxyz',
ALPHA_UPPER: 'ABCDEFGHIJKLMNOPQRSTUVWXYZ',
ALPHA: 'abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ',
ALPHA_NUMERIC: '0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ'
}
function getValue(num, fromBase) {
const fblen = fromBase.length;
const digits = num.toString().split('');
const digitAmt = digits.map(function(digit) {
return fromBase.indexOf(digit) * (fblen**((digits.length - 1) - digits.indexOf(digit)));
});
return digitAmt.reduce(function(n, m) {
return n + m;
});
}
console.log(getValue('fff', Alphabet.HEXA_DECIMAL))
所以我要传递的是num
(例如,'abc'
)和数字的基数(我们将使用HEXA_DECIMAL
)。十六进制数'abc'
的基数为10的等价物将为2748
:
162(10) + 161(11) + 160(12) = 2560 + 176 + 12 = 2748
,当然,这就是函数将产生的结果。但是,如果我输入'fff'
,我就会遇到麻烦。我得到:162(15) + 162(15) + 162(15) = 3840 + 3840 + 3840 = 11520
而不是预期的:162(15) + 161(15) + 160(15) = 3840 + 240 + 15 = 4095
我意识到问题的来源:变量digits.indexOf(digit)
被捕获,因为.indexOf()
只返回第一个实例的索引。现在我不知道如何获得正确的索引号,这将计算正确的指数并使函数按预期工作。
答案 0 :(得分:1)
实际上.map()
将索引传递给回调
var new_array = arr.map(function callback(currentValue, index, array) {
// Return element for new_array
}[, thisArg])
因此,如果您修改下面的代码,它应该可以正常工作
const digitAmt = digits.map(function(digit, index) {
return fromBase.indexOf(digit) * (fblen ** ((digits.length - 1) - index));
});