freeCodeCamp/curriculum/challenges/japanese/02-javascript-algorithms-an.../intermediate-algorithm-scri.../sum-all-odd-fibonacci-numbe...

1.6 KiB

id title challengeType forumTopicId dashedName
a5229172f011153519423690 すべての奇数のフィボナッチ数を合計する 1 16084 sum-all-odd-fibonacci-numbers

--description--

正の整数 num が与えられたときに、num 以下の奇数のフィボナッチ数の和を返してください。

フィボナッチ数列の最初の 2 つの数字は 1 と 1 です。 数列内の他の数はすべて、前の 2 つの数の和になっています。 フィボナッチ数列の最初の 6 つの数字は、1、1、2、3、5、8 です。

たとえば、sumFibs(10) は、10 以下のすべての奇数のフィボナッチ数が 1、1、3、5 なので、10 を返す必要があります。

--hints--

sumFibs(1) は数値を返す必要があります。

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

sumFibs(1000) は 1785 を返す必要があります。

assert(sumFibs(1000) === 1785);

sumFibs(4000000) は 4613732 を返す必要があります。

assert(sumFibs(4000000) === 4613732);

sumFibs(4) は 5 を返す必要があります。

assert(sumFibs(4) === 5);

sumFibs(75024) は 60696 を返す必要があります。

assert(sumFibs(75024) === 60696);

sumFibs(75025) は 135721 を返す必要があります。

assert(sumFibs(75025) === 135721);

--seed--

--seed-contents--

function sumFibs(num) {
  return num;
}

sumFibs(4);

--solutions--

function sumFibs(num) {
  var a = 1;
  var b = 1;
  var s = 0;
  while (a <= num) {
    if (a % 2 !== 0) {
      s += a;
    }
    a = [b, b=b+a][0];
  }
  return s;
}