## DEV Community # Front Matter

Here we are, attempting the Dark Souls of coding challenges. We'll start today with a fairly simple one: getting multiples of 3 and 5.

# Problem 1: Multiples of 3 and 5

If we list all the natural numbers below 10 that are multiples of 3 or 5, we get 3, 5, 6 and 9. The sum of these multiples is 23.

Find the sum of all the multiples of 3 or 5 below the provided parameter value `number`.

# Solution

At first glance, this seems more complicated than it actually is. For the purpose of learning, I am going to be as verbose as possible, then refactor later.

## Breakdown of the Problem in Plain English

It's important to break down all the elements of the problem, so we fully understand what we are trying to do.

### Natural Number

the positive integers (whole numbers) 1, 2, 3, etc., and sometimes zero as well.

### Multiple of `x`

When we say,

"is 6 a multiple of 3?"

"is 6 a number that can be calculated by multiplying 3 by a number (in our case whole numbers)"

In this case, yes, 3 x 2 = 6.

## Steps

Now that we understand our problem, let's make some logical statements.

1. Given a number, see if it is a multiple of 3
2. If true, add it to a total number
3. Given a number, see if it is a multiple of 5
4. If true, add it to a total number

Let's break it down in the code. Again, this is very verbose.

``````    function multiplesOf3and5(number) {
// establish a global total and set initial value to 0
let total = 0
// loop through all values from 0 to given number
for(let i = 0; i <= number; i++) {
// Get remainder of i and 3
let remainderFor3 = i % 3;
// Get remainder of i and 5
let remainderFor5 = i % 5;

// check if remainder for 3 or 5
if(remainderFor3 == 0 || remainderFor5 == 0) {
// If true, that means i is a multiple of 3
// add it to the total
total = total + i
}
}
// return our total number
}
``````

## Explanation of Modulo `%`

This line here is doing something interesting:

``````    i % 3
``````

The operator in the middle is called a Modulus. It returns the remainder of two numbers. We can use it to see if one number is an even multiple of another number.

## Refactor

We can reduce the code quite a lot, without losing the context of what we are trying to do. Here is my final solution.

``````    function multiplesOf3and5(number) {
let total = 0;
for (let i = 0; i <= number; i++) {
if (i % 3 == 0 || i % 5 == 0) {
total += i;
}
}
}
``````

# Final Thoughts

There is always room for improvement, however I like how this is setup. It's simple and doesn't abstract too far from what we are trying to accomplish. I'm certain if I come back to this in two years, I'll still know what's going on.

If you'd like to see the code, check out my Github repo with the problems I've completed so far.

DarthOstrich/projectEuler

# Resources

Introducing The #ProjectEuler100 Challenge: the "Dark Souls" of Coding Achievements  