Intermediate code solution doesn't pass tests when the greater number is even because it's the starting acc without passing the reducer function that avoids even number. Proposed solution: reverse the array before reduce.
		
			
				
	
	
	
		
			6.1 KiB
		
	
	
	
	
	
	
	
			
		
		
	
	title
| title | 
|---|
| Sum All Odd Fibonacci Numbers | 
 Remember to use
 Remember to use Read-Search-Ask if you get stuck. Try to pair program  and write your own code
 and write your own code 
 Problem Explanation:
 Problem Explanation:
You will need to gather all the Fibonacci numbers and then check for the odd ones. Once you get the odd ones then you will add them all. The last number should be the number given as a parameter if it actually happens to be an off Fibonacci number.
Relevant Links
 Hint: 1
 Hint: 1
To get the next number of the series, you need to add the current one to the previous and that will give you the next one.
try to solve the problem now
 Hint: 2
 Hint: 2
To check if a number is even all you have to check is if number % 2 == 0.
try to solve the problem now
 Hint: 3
 Hint: 3
As you get the next odd one, don't forget to add it to a global variable that can be returned at the end. result += currNumber; will do the trick.
try to solve the problem now
Spoiler Alert!
Solution ahead!
 Basic Code Solution:
 Basic Code Solution:
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);
Code Explanation:
- Create a variable to keep record of the current and previous numbers along with the result that will be returned.
- Use a while loop to make sure we do not go over the number given as parameter.
- We use the modulo operand to check if the current number is odd or even. If it is even, add it to the result.
- Complete the Fibonacci circle by rotating getting the next number and swapping values after.
- Return the result.
Relevant Links
- JS while Loop
 Intermediate Code Solution:
 Intermediate Code Solution:
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
    // First, reverse the array to avoid starting acc with the first/greater number when it's even
    return arrFib.reverse().reduce((acc, curr) => {
        return acc + curr * (curr % 2);
    });
}
// test here
sumFibs(4);
Code Explanation:
- Create an array of fibonacci numbers till num.
- Use reduce()method to find the sum of odd members of array.
- Return the sum.
Relevant Links
 NOTES FOR CONTRIBUTIONS:
 NOTES FOR CONTRIBUTIONS:
 DO NOT add solutions that are similar to any existing solutions. If you think it is similar but better, then try to merge (or replace) the existing similar solution. DO NOT add solutions that are similar to any existing solutions. If you think it is similar but better, then try to merge (or replace) the existing similar solution.
- Add an explanation of your solution.
- Categorize the solution in one of the following categories — Basic, Intermediate and Advanced.  
- Please add your username only if you have added any relevant main contents. ( DO NOT remove any existing usernames) DO NOT remove any existing usernames)
See

Wiki Challenge Solution Templatefor reference.

