我需要一个函数,给定一个数字,比如123,它将输出一个数组[100,20,3]。我试过这样的东西(借用SO上的另一个问题):
function separateNumberIntoUnits(n) {
var arr = [];
var i = 10;
while (n > i / 10)
{
arr.unshift(n % i - n % (i / 10));
i *= 10;
}
return arr;
}
它适用于除10、100等之外的所有数字。我试图弄清楚发生了什么,但数学不是我的强项。。。
如果有更有效的方法可以做到这一点,请随时编写自己的解决方案。
我认为这是最有效的方法:
function separateNumberIntoUnits(n) {
if (n == 0) return [0];
// n = Math.floor(n); // needed for decimal numbers
var arr = [];
var i = 1;
while (n > 0) {
arr.unshift((n % 10) * i);
n = Math.floor(n / 10);
i *= 10
}
return arr;
}
document.writeln(separateNumberIntoUnits(1234) + "<br />")
document.writeln(separateNumberIntoUnits(100) + "<br />")
document.writeln(separateNumberIntoUnits(10) + "<br />")
document.writeln(separateNumberIntoUnits(1) + "<br />")
document.writeln(separateNumberIntoUnits(0) + "<br />")
unshift
是最好的方法:Array.unshift vs Array.push和Array.reverse:https://jsperf.com/array-unshift-vs-array-push-and-array-reverse
您可以将数字视为字符串。
将其拆分为一个数字数组,然后通过乘以10的适当幂将每个数字map
到其小数位数:
function separateNumberIntoUnits(n) {
var s= n.toString().split('');
return s.map(function(digit, n) {
return digit * Math.pow(10, s.length - n - 1);
});
}
document.body.innerHTML=
separateNumberIntoUnits(1234) + '<br>' +
separateNumberIntoUnits(100) + '<br>' +
separateNumberIntoUnits(0);
一个没有数学的解决方案:
function s(n) {
return n.toString().split('').reduce(function (r, a) {
r = r.map(function (b) { return b + '0'; });
r.push(a);
return r;
}, []);
}
document.body.textContent = s(321);
这里有一个易于理解的基本解决方案。最低数学要求。
function separateUnits(num) {
var number = num.toString().split('');
var multiplier = 1;
for (var i = number.length - 1; i >= 0; i--) {
number[i] *= multiplier;
multiplier *= 10;
}
return number;
}
separateUnits(2134);
输出
[2000, 100, 30, 4]