2020-09-29 22:09:05 +02:00

2.0 KiB
Raw Blame History

id, title, challengeType, forumTopicId, localeTitle
id title challengeType forumTopicId localeTitle
a5229172f011153519423690 Sum All Odd Fibonacci Numbers 5 16084 求斐波那契数组中的奇数之和

Description

在这道题目中,我们需要写一个函数,参数为一个正整数num。它的作用是计算斐波那契数列中,小于或等于num的奇数之和。 斐波那契数列中,第一和第二个数字都是 1后面的每个数字由之前两数相加得出。斐波那契数列的前六个数字分别为1、1、2、3、5、8。 比如,sumFibs(10)应该返回10。因为斐波那契数列中,比10小的数字只有 1、1、3、5。 如果你遇到了问题,请点击帮助

Instructions

Tests

tests:
  - text: <code>sumFibs(1)</code>应该返回一个数字。
    testString: assert(typeof sumFibs(1) === "number");
  - text: <code>sumFibs(1000)</code>应该返回 1785。
    testString: assert(sumFibs(1000) === 1785);
  - text: <code>sumFibs(4000000)</code>应该返回 4613732。
    testString: assert(sumFibs(4000000) === 4613732);
  - text: <code>sumFibs(4)</code>应该返回 5。
    testString: assert(sumFibs(4) === 5);
  - text: <code>sumFibs(75024)</code>应该返回 60696。
    testString: assert(sumFibs(75024) === 60696);
  - text: <code>sumFibs(75025)</code>应该返回 135721。
    testString: assert(sumFibs(75025) === 135721);

Challenge Seed

function sumFibs(num) {
  return num;
}

sumFibs(4);

Solution

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;
}