DEV Community

Cover image for Let's code golf with JavaScript!
Posandu
Posandu

Posted on • Originally published at tronic247.com

Let's code golf with JavaScript!

In this article, we'll golf some JavaScript code. But first, we'll need to know what the heck is code-golf?

What is code-golf?

Code golfing is trying to make the shortest possible code for a given task. It's mainly a game and very useful for improving your programming skills. There are many sites where you can code golf. Here's a list of some of the most popular sites:

Get started!

We'll code-golf the easiest challenge that is Fizz-Buzz (https://code.golf/fizz-buzz). Our task is to print all the numbers from 1 to 100. But instead of printing the numbers, we'll print the word "Fizz" if the number is divisible by 3, "Buzz" if the number is divisible by 5, and "FizzBuzz" if the number is divisible by both 3 and 5.

So first we'll make a basic program that prints all the numbers from 1 to 100.

for (let i = 1; i <= 100; i++) {
    console.log(i);
}
Enter fullscreen mode Exit fullscreen mode

Now we can see all the numbers from 1 to 100. But we need to add the logic to print Fizz, Buzz, or FizzBuzz.

for (let i = 1; i <= 100; i++) {
    if (i % 3 === 0 && i % 5 === 0) {
        console.log("FizzBuzz");
    } else if (i % 3 === 0) {
        console.log("Fizz");
    } else if (i % 5 === 0) {
        console.log("Buzz");
    } else {
        console.log(i);
    }
}
Enter fullscreen mode Exit fullscreen mode

But that's 240 bytes! Now we code-golf it!

Reduce the length of the for loop condition

The current for loop statement is:

let i = 1;
i <= 100;
i++;
Enter fullscreen mode Exit fullscreen mode

We can remove the i++ part and replace i<=100 with i++<100. So our for loop will look like this:

let i = 0;
i++ < 100;
Enter fullscreen mode Exit fullscreen mode

Now we reduced the code to 225 bytes.

Convert if-else to a single line

We can make the if-else statement into a single line using the ? operator.

for (let i = 0; i++ < 100; ) {
    console.log(
        i % 3 === 0 ? (i % 5 === 0 ? "FizzBuzz" : "Fizz") : i % 5 === 0 ? "Buzz" : i
    );
}
Enter fullscreen mode Exit fullscreen mode

We removed 103 bytes.

Remove let keyword

Because we don't use any scope, we can remove the let keyword.

Replace console.log with print

We can replace console.log with print and reduce the code to 112 bytes.

Create a variable for saving Fizz

We'll create a variable like this.

f = i % 3 ? "" : "Fizz";
Enter fullscreen mode Exit fullscreen mode

Look at the below diagram.

Now we use this logic in the print function.

print(i % 5 ? f || i : f + "Buzz");
Enter fullscreen mode Exit fullscreen mode

Don't get confused πŸ˜‰. Here's how it works:

First, we check if i % 5 is not zero. That means i % 5 is not divisible by 5. So we again check if f is empty. If f is empty, we print i else we print f.

If i % 5 returns zero, that means i % 5 is divisible by 5. So we just print f + "Buzz".

And that will make our code look like this:

for (i = 0; i++ < 100; ) {
    f = i % 3 ? "" : "Fizz";
    print(i % 5 ? f || i : f + "Buzz");
}
Enter fullscreen mode Exit fullscreen mode

That's 92 bytes.

Move the print function to the loop header

We can move the print function to the loop header.

for (i = 0; i++<100;print(i % 5 ? f || i : f + "Buzz"))
//..
Enter fullscreen mode Exit fullscreen mode

And we can remove the {} braces because there's only one statement.

for (i = 0; i++ < 100; print(i % 5 ? f || i : f + "Buzz"))
    f = i % 3 ? "" : "Fizz";
Enter fullscreen mode Exit fullscreen mode

Our code is getting shorter and shorter. Now it's 79 bytes.

Remove all spaces

This is the most basic thing but I do it last.

for(i=0;i++<100;print(i%5?f||i:f+"Buzz"))f=i%3?"":"Fizz";
Enter fullscreen mode Exit fullscreen mode

Now we've made the shortest possible Fizz Buzz in JavaScript. Which are 56 bytes. πŸŽ‰πŸŽ‰

Conclusion

Now that you know the basics of code golf, play with the code golfing challenges improve your knowledge and have fun!

Find me on GitHub.
You can also follow me on Twitter.

Top comments (2)

Collapse
 
frankwisniewski profile image
Frank Wisniewski

JavaScript does not have any print object or print methods.
You can only print the content of the current window -> blank page.

Collapse
 
posandu profile image
Posandu

Yep! It only applies for node.js based environments.