freeCodeCamp/curriculum/challenges/italian/10-coding-interview-prep/project-euler/problem-63-powerful-digit-c...

2.2 KiB

id title challengeType forumTopicId dashedName
5900f3ab1000cf542c50febe Problema 63: Conteggio cifre potenti 5 302175 problem-63-powerful-digit-counts

--description--

Il numero a 5 cifre, 16807 = 75, è anche una quinta potenza. Analogamente, il numero a 9 cifre, 134217728 = 89, è una nona potenza.

Completa la funzione in modo che restituisca quanti interi positivi siano di lunghezza n e nma potenza.

--hints--

powerfulDigitCounts(1) dovrebbe restituire un numero.

assert(typeof powerfulDigitCounts(1) === 'number');

powerfulDigitCounts(1) dovrebbe restituire 9.

assert.strictEqual(powerfulDigitCounts(1), 9);

powerfulDigitCounts(2) dovrebbe restituire 6.

assert.strictEqual(powerfulDigitCounts(2), 6);

powerfulDigitCounts(3) dovrebbe restituire 5.

assert.strictEqual(powerfulDigitCounts(3), 5);

powerfulDigitCounts(4) dovrebbe restituire 4.

assert.strictEqual(powerfulDigitCounts(4), 4);

powerfulDigitCounts(5) dovrebbe restituire 3.

assert.strictEqual(powerfulDigitCounts(5), 3);

powerfulDigitCounts(6) dovrebbe restituire 3.

assert.strictEqual(powerfulDigitCounts(6), 3);

powerfulDigitCounts(7) dovrebbe restituire 2.

assert.strictEqual(powerfulDigitCounts(7), 2);

powerfulDigitCounts(8) dovrebbe restituire 2.

assert.strictEqual(powerfulDigitCounts(8), 2);

powerfulDigitCounts(10) dovrebbe restituire 2.

assert.strictEqual(powerfulDigitCounts(10), 2);

powerfulDigitCounts(21) dovrebbe restituire 1.

assert.strictEqual(powerfulDigitCounts(21), 1);

--seed--

--seed-contents--

function powerfulDigitCounts(n) {

  return true;
}

powerfulDigitCounts(1);

--solutions--

function powerfulDigitCounts(n) {
  function countDigits(num) {
    let counter = 0;
    while (num > 0) {
      num = Math.floor(num / 10);
      counter++;
    }
    return counter;
  }

  let numbersCount = 0;

  let curNum = 1;
  while (curNum < 10) {
    let power = n;
    if (power === countDigits(curNum ** power)) {
      numbersCount++;
    }
    curNum++;
  }

  return numbersCount;
}