124 lines
7.8 KiB
Markdown
124 lines
7.8 KiB
Markdown
![]() |
---
|
|||
|
title: Sum All Odd Fibonacci Numbers
|
|||
|
localeTitle: Сумма всех нечетных чисел Фибоначчи
|
|||
|
---
|
|||
|
 Не забудьте использовать **`Read-Search-Ask`** если вы застряли. Попробуйте подключить программу  и напишите свой собственный код 
|
|||
|
|
|||
|
###  Проблема Объяснение:
|
|||
|
|
|||
|
Вам нужно будет собрать все **числа Фибоначчи,** а затем проверить нечетные. Как только вы получите нечетные, вы добавите их все. Последним номером должно быть число, заданное как параметр, если оно фактически является выключенным числом Фибоначчи.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [Число Фибоначчи](https://en.wikipedia.org/wiki/Fibonacci_number)
|
|||
|
|
|||
|
##  Подсказка: 1
|
|||
|
|
|||
|
Чтобы получить следующий номер серии, вам нужно добавить текущий к предыдущему, и это даст вам следующий.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 2
|
|||
|
|
|||
|
Чтобы проверить, действительно ли номер, все, что вам нужно проверить, это `number % 2 == 0` .
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
##  Подсказка: 3
|
|||
|
|
|||
|
Когда вы получите следующий нечетный, не забудьте добавить его в глобальную переменную, которая может быть возвращена в конце. `result += currNumber;` будет делать трюк.
|
|||
|
|
|||
|
> _попытаться решить проблему сейчас_
|
|||
|
|
|||
|
## Осторожно, спойлеры!
|
|||
|
|
|||
|

|
|||
|
|
|||
|
**Решение впереди!**
|
|||
|
|
|||
|
##  Решение базового кода:
|
|||
|
```
|
|||
|
function sumFibs(num) {
|
|||
|
var prevNumber = 0;
|
|||
|
var currNumber = 1;
|
|||
|
var result = 0;
|
|||
|
while (currNumber <= num) {
|
|||
|
if (currNumber % 2 !== 0) {
|
|||
|
result += currNumber;
|
|||
|
}
|
|||
|
|
|||
|
currNumber += prevNumber;
|
|||
|
prevNumber = currNumber - prevNumber;
|
|||
|
}
|
|||
|
|
|||
|
return result;
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
sumFibs(4);
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/CLnV/0)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
* Создайте переменную, чтобы вести запись текущего и предыдущего номеров вместе с результатом, который будет возвращен.
|
|||
|
* Используйте цикл while, чтобы убедиться, что мы не переходим через число, указанное как параметр.
|
|||
|
* Мы используем операнд по модулю, чтобы проверить, является ли текущий номер нечетным или четным. Если он четный, добавьте его в результат.
|
|||
|
* Завершите круг Фибоначчи, повернув следующий номер и меняя значения.
|
|||
|
* Верните результат.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* JS while Loop
|
|||
|
|
|||
|
##  Решение промежуточного кода:
|
|||
|
```
|
|||
|
function sumFibs(num) {
|
|||
|
// Perform checks for the validity of the input
|
|||
|
if (num < 0) return -1;
|
|||
|
if (num === 0 || num === 1) return 1;
|
|||
|
|
|||
|
// Create an array of fib numbers till num
|
|||
|
const arrFib = [1, 1];
|
|||
|
let nextFib = 0;
|
|||
|
|
|||
|
// We put the new Fibonacci numbers to the front so we
|
|||
|
// don't need to calculate the length of the array on each
|
|||
|
// iteration
|
|||
|
while((nextFib = arrFib[0] + arrFib[1]) <= num) {
|
|||
|
arrFib.unshift(nextFib);
|
|||
|
}
|
|||
|
|
|||
|
// Sum only the odd numbers and return the value
|
|||
|
return arrFib.reduce((acc, curr) => {
|
|||
|
return acc + curr * (curr % 2);
|
|||
|
});
|
|||
|
}
|
|||
|
|
|||
|
// test here
|
|||
|
sumFibs(4);
|
|||
|
```
|
|||
|
|
|||
|
 [Код запуска](https://repl.it/@kr3at0/SumAllOddFibonacciNumbers)
|
|||
|
|
|||
|
### Код Объяснение:
|
|||
|
|
|||
|
* Создайте массив чисел фибоначчи до **num** .
|
|||
|
* Используйте метод `reduce()` чтобы найти сумму нечетных элементов массива.
|
|||
|
* Верните сумму.
|
|||
|
|
|||
|
#### Связанные ссылки
|
|||
|
|
|||
|
* [JS Array Prototype Push](http://forum.freecodecamp.com/t/javascript-array-prototype-push/14298)
|
|||
|
* [JS для пояснений](http://forum.freecodecamp.com/t/javascript-for-loop/14666s-Explained)
|
|||
|
* [Сокращение прототипа JS](http://forum.freecodecamp.com/t/javascript-array-prototype-reduce/14299)
|
|||
|
|
|||
|
##  ПРИМЕЧАНИЯ ДЛЯ ВЗНОСОВ:
|
|||
|
|
|||
|
*  **НЕ** добавляйте решения, похожие на любые существующие решения. Если вы считаете, что это **_похоже, но лучше_** , попробуйте объединить (или заменить) существующее подобное решение.
|
|||
|
* Добавьте объяснение своего решения.
|
|||
|
* Классифицируйте решение в одной из следующих категорий - **Basic** , **Intermediate** и **Advanced** . 
|
|||
|
* Пожалуйста, добавьте свое имя пользователя, только если вы добавили **соответствующее основное содержимое** . (  **_НЕ_** _удаляйте существующие имена пользователей_ )
|
|||
|
|
|||
|
> Увидеть  [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для [**`Wiki Challenge Solution Template`**](http://forum.freecodecamp.com/t/algorithm-article-template/14272) для справки.
|