在 JavaScript 中查找数字的位值
我们需要编写一个函数,比如 splitNumber(),该函数接受一个正整数并返回一个数组,其中填充了该数字所有位的位值。
例如 -
如果输入数字是 -
const num = 1234;
输出
则输出应为 -
const output = [1000, 200, 30, 4];
我们来编写此函数的代码。
此问题非常适合递归方法,因为我们将对数字的每个位进行迭代。
因此,返回位值数组的递归函数将为 -
示例
const splitNumber = (num, arr = [], m = 1) => {
if(num){
return splitNumber(Math.floor(num / 10), [m * (num % 10)].concat(arr), m * 10);
}
return arr;
};
console.log(splitNumber(2346));
console.log(splitNumber(5664));
console.log(splitNumber(3453));
console.log(splitNumber(2));
console.log(splitNumber(657576));
console.log(splitNumber(345232));输出
控制台中的输出 -
[ 2000, 300, 40, 6 ] [ 5000, 600, 60, 4 ] [ 3000, 400, 50, 3 ] [ 2 ] [ 600000, 50000, 7000, 500, 70, 6 ] [ 300000, 40000, 5000, 200, 30, 2 ]
广告
数据结构
网络
RDBMS
操作系统
Java
iOS
HTML
CSS
Android
Python
C 程序设计
C++
C#
MongoDB
MySQL
Javascript
PHP