2.0 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	id, title, challengeType, forumTopicId, dashedName
| id | title | challengeType | forumTopicId | dashedName | 
|---|---|---|---|---|
| 594810f028c0303b75339ad1 | Números felizes | 5 | 302280 | happy-numbers | 
--description--
Um número feliz é definido pelo processo a seguir:
Começando por qualquer número inteiro positivo, substitua o número pela soma dos quadrados de seus dígitos. Repita o processo até que o número seja igual a 1 (onde ele permanecerá), ou faça laços infinitamente em um ciclo que não inclui o 1. Os números para os quais este processo termina em 1 são números felizes, enquanto aqueles que não terminam em 1 são números infelizes.
--instructions--
Implementa uma função que retorna true se o número for feliz ou false se não for.
--hints--
happy deve ser uma função.
assert(typeof happy === 'function');
happy(1) deve retornar um booleano.
assert(typeof happy(1) === 'boolean');
happy(1) deve retornar true.
assert(happy(1));
happy(2) deve retornar false.
assert(!happy(2));
happy(7) deve retornar true.
assert(happy(7));
happy(10) deve retornar true.
assert(happy(10));
happy(13) deve retornar true.
assert(happy(13));
happy(19) deve retornar true.
assert(happy(19));
happy(23) deve retornar true.
assert(happy(23));
happy(28) deve retornar true.
assert(happy(28));
happy(31) deve retornar true.
assert(happy(31));
happy(32) deve retornar true.
assert(happy(32));
happy(33) deve retornar false.
assert(!happy(33));
--seed--
--seed-contents--
function happy(number) {
}
--solutions--
function happy (number) {
  let m;
  let digit;
  const cycle = [];
  while (number !== 1 && cycle[number] !== true) {
    cycle[number] = true;
    m = 0;
    while (number > 0) {
      digit = number % 10;
      m += Math.pow(digit, 2);
      number = (number - digit) / 10;
    }
    number = m;
  }
  return (number === 1);
}