在 JavaScript 中统计到 n 为止的 1 的数量
我们需要编写一个 JavaScript 函数,它接受一个正整数(比如说 num)。
函数的任务是统计出现于所有正整数中(包括 n,如果它包含任何 1)的 1 的总数。
然后,该函数应最终返回此计数。
例如 −
如果输入数字为 −
const num = 31;
那么输出应为 −
const output = 14;
因为 1 出现于以下地方,
1, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 21, 31
示例
以下为代码 −
const num = 31; const countOnes = (num = 1) => { if(num <= 0 ){ return 0 }; let sum = 0 num += ''; let helper = p => { let leftNum = 0 let rightNum = 0 let di = num[p] if(p>0){ leftNum = parseInt(num.slice(0,p)) } if(p+1 < num.length){ rightNum = parseInt(num.slice(p+1)) } if(di > 1){ sum += (leftNum+1)*(10**(num.length-1-p)) } else if(di == 0){ sum += (leftNum)*(10**(num.length-1-p)) } else{ sum += (leftNum)*(10**(num.length-1-p)) + rightNum + 1 } } for(let i =0; i < num.length; i++){ helper(i) }; return sum; }; console.log(countOnes(num));
输出
以下为控制台输出 −
14
广告