2.5 KiB
2.5 KiB
title, id, localeTitle, challengeType
title | id | localeTitle | challengeType |
---|---|---|---|
Harshad or Niven series | 595668ca4cfe1af2fb9818d4 | 595668ca4cfe1af2fb9818d4 | 5 |
Description
Los números de Harshad o Niven son enteros positivos ≥ 1 que son divisibles por la suma de sus dígitos.
Por ejemplo, 42 es un número de Harshad ya que 42 es divisible por (4 + 2) sin resto.
Supongamos que la serie se define como los números en orden creciente. Tarea:Implementar una función para generar miembros sucesivos de la secuencia de Harshad.
Úselo para enumerar los primeros veinte miembros de la secuencia y enumerar el primer número de Harshad mayor que 1000.
Instructions
Tests
tests:
- text: <code>isHarshadOrNiven</code> es una función.
testString: 'assert(typeof isHarshadOrNiven === "function", "<code>isHarshadOrNiven</code> is a function.");'
- text: ' <code>isHarshadOrNiven()</code> debe devolver <code>{"firstTwenty": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 18, 20, 21, 24, 27, 30, 36, 40, 42],"firstOver1000": 1002}</code> '
testString: 'assert.deepEqual(isHarshadOrNiven(), res, "<code>isHarshadOrNiven()</code> should return <code>{"firstTwenty": [1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 12, 18, 20, 21, 24, 27, 30, 36, 40, 42],"firstOver1000": 1002}</code>");'
Challenge Seed
function isHarshadOrNiven () {
const res = {
firstTwenty: [],
firstOver1000: undefined
};
// Change after this line
return res;
}
After Test
console.info('after the test');
Solution
function isHarshadOrNiven() {
const res = {
firstTwenty: [],
firstOver1000: undefined
};
function isHarshad(n) {
let s = 0;
const nStr = n.toString();
for (let i = 0; i < nStr.length; ++i) {
s += parseInt(nStr.charAt(i), 10);
}
return n % s === 0;
}
let count = 0;
const harshads = [];
for (let n = 1; count < 20; ++n) {
if (isHarshad(n)) {
count++;
harshads.push(n);
}
}
res.firstTwenty = harshads;
let h = 1000;
while (!isHarshad(++h));
res.firstOver1000 = h;
return res;
}