Home/Blog/Learn to Code/Level up your JavaScript skills with 10 coding challenges
Home/Blog/Learn to Code/Level up your JavaScript skills with 10 coding challenges

Level up your JavaScript skills with 10 coding challenges

16 min read
Aug 03, 2020
content
Longest String in an ArrayPromptApproachWhat is our Input?What is our Output?Questions to ask the interviewer:Longest String PlanPossible SolutionExplanationMost Commonly Used Character in StringPromptApproachWhat is our Input?What is Our Output?Questions to ask the interviewer:Most Used Char PlanPossible SolutionExplanationTwo Strings Are Anagrams of Each OtherPromptApproachWhat is our Input?What is Our Output?Questions to ask the interviewer:Anagrams PlanPossible SolutionExplanationString Permutation is Palindrome?PromptApproachWhat is our Input?What is our Output?Questions to ask the interviewer:Palindromes PlanPossible SolutionExplanationKeep the learning going.Balanced BracketsPromptApproachWhat is our Input?What is our Output?Questions to ask the interviewer:Balanced Brackets PlanPossible SolutionExplanationArmstrong NumbersPromptApproachWhat is our Input?What is our Output?Questions to ask the interviewer:Armstrong Number PlanPossible SolutionExplanationSorting ObjectsPromptApproachWhat is our Input?What is Our Output?SortObjects PlanPossible SolutionExplanationReverse a Linked ListPromptApproachWhat is our Input?What is our Output?Questions to Possibly Ask InterviewerReverse a Linked List PlanPossible SolutionExplanationRemove Kth-Node from Linked ListPromptApproachWhat is our Input?What is our Output?Questions to Possibly Ask InterviewerLinkedList Delete K-th Node PlanPossible SolutionCircular Linked ListPromptApproachWhat is our Input?What is our Output?Questions to Possibly Ask InterviewerReverse a Linked List PlanPossible SolutionExplanationWrapping upContinue reading about JavaScript

Become a Software Engineer in Months, Not Years

From your first line of code, to your first day on the job — Educative has you covered. Join 2M+ developers learning in-demand programming skills.

The best way to learn to code in JavaScript is to practice, practice, practice. That’s why today we will go over 10 coding challenges to level up your JavaScript skills. These exercises are useful for any JavaScript developer. If you’re an absolute beginner, it will be helpful to check out our beginner’s guide before diving in.

JavaScript challenges can be difficult enough without us trying to make them harder for ourselves. One of the ways to make them easier is to follow principles outlined in a short book by George Polya called How To Solve It. These steps are as follows:

  1. Understand the Problem
  2. Make a Plan
  3. Execute Plan
  4. Refactor - is There a Way to Make it Better?

As we challenge ourselves in the next ten problems, keep these steps in mind. Keep in mind that there are several ways to solve these problems. As long as you can explain your thought-process in good detail, your answer is probably fine!

Cover
Learn HTML, CSS, and JavaScript from Scratch

This course will teach you the fundamentals of creating web applications, from the basics of creating web pages with HTML, stylizing content with CSS, all the way to building interactivity into a page using JavaScript in the browser. Instead of watching tedious videos and wondering how to translate those videos into real code, you'll be practicing what you learn through interactive, test-based exercises within minutes. Along the way, you'll be able to produce functional modules, including an image carousel and a to-do list application. No prior knowledge is needed.

10hrs
Beginner
41 Challenges
19 Quizzes

Longest String in an Array#

Prompt#

Write a function that accepts an array of strings. Return the longest string.

Approach#

What is our Input?#

  • String[] = an array of strings

What is our Output?#

  • String = the longest of the strings in the array

Questions to ask the interviewer:#

Do we need to consider if there are no strings in the array?

  • For this challenge, no

Do we need to consider times when all of the strings are the same length?

  • Yes. Return the first string.

Longest String Plan#

For this problem, we need to:

  1. Initialize and Declare Variable for Longest String
  2. Loop through the array
  3. Find the length of each string
  4. Determine if that length is the largest we have seen so far.
  5. Replace the longest/largest variable with the arr[index] as long as length is greater than the variable.
  6. Return longest/largest string.

Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

There are two different ways listed here as a possible solution to this problem: one uses the ES5 Syntax and uses the ES6 Syntax.

  1. In both solutions, we initially need to declare a longest variable and initialize it to an empty string.

  2. In the ES5 solution, we are utilizing a traditional for loop structure to look at each index in the array. We are using the array method forEach to iterate over the array in the ES6 solution.

  3. As we iterate through the data structure, we want to take a look at the length of each string. In JavaScript, we can do that with the length property.

  4. In the ES5 solution, we utilized a conditional statement to see if the current (arr[i]) string’s length is longer than (but not equal to) the current longest string(longest). The ES6 solution takes another approach with using the Math object property max as a shortcut for the conditional logic in the ES5 version.

  5. If the string is longer, we assign it to the longest variable we already created.

  6. Return the longest as our function’s terminal statement in both cases.

Most Commonly Used Character in String#

Prompt#

Write a function that takes a string, and returns the character that is most commonly used in the string.

Approach#

What is our Input?#

  • String = one String

What is Our Output?#

  • String = the single character that shows up the most in the given string

Questions to ask the interviewer:#

Do we need to consider if there is no string given?

  • For this challenge, no

Do we need to consider times when more than one character shows up the same number of times?

  • No. Return the last one.

Most Used Char Plan#

To find the character most often used in a string, we need to be able to count how many of each kind we have. We can do this using an object that has key:value pairs.

  1. Define and Initialize an object
  2. Map character count to that object.
  3. Loop through the object to find the max count.
  4. Assign new max count value to maxCharCount and new max key to maxChar.
  5. Return maxChar

Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

  1. Create a charCount object. This object can be named whatever you’d like as long as it’s consistent.

  2. Use a standard for loop to iterate through the string, and check to see if it exists in the charCount object. If it does, add 1 to CharCount[key] and reassign it to the same variable. The pipes here will cover any instance where the key does not yet exist in the object and initialize the count to 1.

  3. Loop through the object using a for...in loop. This type of loop allows us to iterate over each property in an object to look at its value. In this instance we want to find the largest number.

  4. The wording for this problem indicates that they want us to find the last max number (in the case there is more than one character with the same amount of appearances), so we use >= to reassign the maxChar if needed.

  5. Return our maxChar.

Two Strings Are Anagrams of Each Other#

Prompt#

Create a function that takes in two strings as two parameters and returns a boolean that indicates whether or not the first string is an anagram of the second string.

Approach#

What is our Input?#

  • String, String = two Strings

What is Our Output?#

  • Boolean are either true or false. True if they are anagrams of each other, and false if they are not.

Questions to ask the interviewer:#

What is an anagram?

  • An anagram is another word or phrase formed by rearranging letters of the first word or phrase.

Do we need to consider whitespace?

  • Trim whitespace prior to comparison.

Anagrams Plan#

If an anagram is just a bunch of letters jumbled around, we can see if the strings are anagrams of each other by:

  1. Comparing the length: if they are not same length, they are not an anagram of the other

  2. Sorting the string and using an equality operator to see if it’s equal.

Possible Solution#

There are a couple of different ways to solve this problem.

// Try it out yourself here before checking the solution!

Explanation#

  1. Compare the length of the first string to the length of the second string. If they are not equal, return false.
  2. If the strings pass the initial check, we sort each individual string, assign it to a variable, and then return the result of setting the variables equal to each other. If they are equal, it will return true. If not, it will return false.

This particular solution considers white space by sorting it to the end of the string, so it doesn’t necessarily matter if it’s counted or not.

String Permutation is Palindrome?#

Prompt#

Given a string, write a function that will return whether or not that string is a palindrome.

Approach#

What is our Input?#

  • String = one String

What is our Output?#

  • Boolean means either true or false. true if string is a palindrome; false if it is not.

Questions to ask the interviewer:#

Do we need to consider whitespace?

  • Do not trim whitespace.

Does the palindrome need to be in the dictionary?

  • No, it does not.

Palindromes Plan#

  1. Reverse the string. We need to keep the old reference to the string to use later. To do this, we need to split string into an array.
  2. Reverse the string.
  3. Join the string.
  4. See if new variation of string is equal to an old variation of string.

Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

This one is deceptively simple. You just need to have knowledge of array methods and how to work with strings in conjunction with those methods. Practice how this could possibly be done without the methods so you know how these methods work under the hood.


Keep the learning going.#

Learn JavaScript without scrubbing through videos or documentation. Educative’s text-based courses are easy to skim and feature live coding environments, making learning quick and efficient.

The Complete Guide to Modern JavaScript


Balanced Brackets#

Prompt#

Given a string possibly containing three types of braces ({}, [], ()), write a function that returns a Boolean indicating whether the given string contains a valid nesting of braces.

Approach#

What is our Input?#

  • String = one String

What is our Output?#

  • Boolean means either true or false. true if string has balanced brackets; false if it does not.

Questions to ask the interviewer:#

What do you mean by balanced brackets?

  • A string is considered balanced if it has as many opening brackets of a given type as it has closing brackets of that same type. No bracket can be left unmatched. A closing bracket also cannot match a corresponding opening bracket that comes after it. Brackets also cannot overlap each other.

Will the string only have brackets in it?

  • No. All chars can be used.

Balanced Brackets Plan#

Because we are looking for nested balanced brackets, we are looking to use a data structure to store the open brackets we have seen so far.

As we come to a closing bracket, we need to look to see if the last bracket added to the data structure matches the opposite of the current bracket.

If your data structure is empty by the time we get to the end of the string, we have balanced brackets.

Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

The process for this particular problem is more about checking for failures. We use a data structure called a stack that takes a first in, last out approach to do that.

When we come across an open bracket, we push it on to the stack. When we come across a closed one, we check to see if the last index of the stack is the opposite the current character.

If the stack is empty by the time we get to the end of our logic, we have balanced brackets.


Armstrong Numbers#

Prompt#

An Armstrong number is an n-digit number that is equal to the sum of the nthnth powers of its digits. Determine if the input number is an Armstrong number. Return either true or false.

Approach#

What is our Input?#

  • Number = n-digit number

What is our Output?#

  • Boolean means either true or false. true if number is Armstrong Number; false if it is not.

Questions to ask the interviewer:#

May I have an example please?

  • 13+53+33=1531^3 + 5^3 + 3^3 = 153

Armstrong Number Plan#

Remember that in JavaScript type coercion exists. When working with Numbers is JS, remember to check the typeof the number. If it is a string, you’ll need to plan for that. This is really important when working with math in JS.

Possible Solution#

// Try it out yourself before clicking on the solution tab!

Explanation#

To solve this problem, we change the number to a string, figure out the power by getting the length of the number, and then use a for loop to add up the individual numbers ^ length of the number passed in.

We then check to see if the sum is equal to the original number. If it is, it is an Armstrong number.


Sorting Objects#


Prompt#

Given an array of objects, sort the objects by population size. Return the entire object.


Approach#

What is our Input?#

  • An array of objects

What is Our Output?#

  • An array of objects, sorted by population

SortObjects Plan#

JavaScript has a built-in array method called sort() that we can use for this particular exercise.

What’s interesting about this particular method is that in JavaScript, if you don’t use a callback compare function to sort the array of objects, the default sort method is used to sort by characters rather than number. For example:

const sortNumbers = (arr) => {
  return arr.sort();
}

console.log(sortNumbers([1, 11, 27, 2, 34, 123])); // [ 1, 11, 123, 2, 27, 34 ]

We need to use a compare function as a callback passed into the sort method to make sure that the actual numbers are treated properly.


Possible Solution#

// Try it out yourself before clicking on the solution tab!

Explanation#

To sort an array of objects by a certain property, we have to use the compare function as a parameter in the built-in sort method in JavaScript.

The compare function takes in two parameters: here they are named a and b. They represent two objects next to each other in our array. If a and b are both objects, we can use dot notation to access the property population.

If we want to be sure that the array has objects sorted by population in increasing order, we evaluate a.population - b.population. If it’s -1, it will put the list in decreasing order by population. The opposite would put it in increasing order. If the expression happens to evaluate to 0, it means that the two patterns are equal to the other.


Reverse a Linked List#


Prompt#

Create a Node class and a LinkedList class with these methods:

  • insertFirst(data)
  • insertLast(data)
  • getFirst()
  • getLast()

Approach#

What is our Input?#

  • Nothing. We are building two classes from scratch that have methods.

What is our Output?#

  • This is a class that will create instances of a LinkedList. We will use it to test the reverse a linked list functionality.

Questions to Possibly Ask Interviewer#

Are we to assume this is a singly-linked list that actually exists?

  • No. Handle all possible errors if you can.

Reverse a Linked List Plan#

The first thing we need to investigate is how a linked list works. Once we have that figured out, it might be a lot easier to write out the code for it.

Linked lists are different from arrays in that they don’t require a continuous place of residence in memory. Linked Lists can be broken up into single nodes if needed as long as the linked list’s next value is not null.

Let’s plan to initialize three variables: prev as NULL, curr as head, and next as NULL. Iterate trough the Linked List. In a while loop, do the following.

  • Store next node
  • next = curr.next
  • Change next of current (this is where the reversing happens)
  • curr.next = prev

Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

We start with the Node class. It will have a data property and a next property. The next property acts as a pointer that will direct us to the next node in our linked list if it exists, or null.

For the Linked List class, we check for failures in our methods before we handle the success. With Linked Lists, we will check to see if the actual list exists by checking to see if the head exists and perform the appropriate logic for each method.

When we reverse a linked list, juggling variables around is the rule of the day. We have one variable, node, that is declared and then initialized to head. We declare tmp and prev without initializing them.

While the node exists, we redirect the pointers by reassigning variables. The result is a reversed linked list.


Remove Kth-Node from Linked List#


Prompt#

Using the Node and LinkedList classes that you created in the previous question, add methods to it so that, when given an kth-integer, you can delete that kthkth node from the linked list


Approach#

What is our Input?#

  • We will add to the Linked List and Node classes that were written in the previous question.

What is our Output?#

  • This is a class that will create instances of a LinkedList. We will use it to test delete a kthkth-node functionality.

Questions to Possibly Ask Interviewer#

Is this a zero-based indexing?

  • Yes.

LinkedList Delete K-th Node Plan#

When given K we have to be able to delete that node in a linked list. To handle edge cases, we need to have some knowledge of the size of the list, the node prior to the Kth node and the node after the Kth node. We essentially need to redirect the pointers for those nodes to not include the one we want to be deleted.

To do that, we’ll loop through the list, keep track of which node we’re on, and change the pointers to skip the Kth-node. It’ll still be in memory, ready to be written over, but it will be essentially deleted from our list.


Possible Solution#

// Try it out yourself here before checkin the solution!

Circular Linked List#


Prompt#

Given a linked list, return true if the list is circular, false if it is not.


Approach#

What is our Input?#

  • A new LinkedList()

What is our Output?#

A Boolean that tells us if the linked list is circular or not.


Questions to Possibly Ask Interviewer#

What does it mean for a linked list to be circular?

  • It means that a next node value could point to a node that we have already seen in our linked list.

Reverse a Linked List Plan#

We will have two pointers: one slow and one fast. The fast one will move twice as much as the slow one on each iteration. If it comes to be that the fast.next.next value doesn’t exist, we can assume it’s a linear linked list. If the slow pointer and the fast pointer ultimately end up equal, we know we have a circular component to our list.


Possible Solution#

// Try it out yourself here before checking the solution!

Explanation#

Here we declare and initialize two pointers, one slow and one fast, that are both pointed at the head. While the next two nodes exist, we’ll reassign the pointers: the slow will move to the next node and the fast will move two nodes.

If the slow ever is the same value as the fast, we have a circular linked list. If ever one of the two nodes past the current node doesn’t exist, we’ll break the loop and return false.


Cover
Learn Coding Basics in JavaScript

The demand for skilled JavaScript programmers is increasing in today's tech-driven world. This comprehensive course is for individuals with no prior programming experience—it provides an accessible learning path for beginners. Throughout the course, you will gain a strong grasp of JavaScript syntax, enabling you to craft dynamic and engaging online content. You will start by learning the basic concepts in programming such as conditional statements, arrays, functions, and loops and then move on to advanced topics such as the Document Object Model (DOM), event handling, and classes in JavaScript. This comprehensive coverage empowers you to grasp the intricacies of JavaScript for practical web development applications. After taking this hands-on learning course, you’ll be equipped with the necessary skills for entry-level web development roles. You’ll possess a solid foundation in JavaScript and the confidence to design and develop interactive web experiences.

25hrs
Beginner
4 Challenges
14 Quizzes

Wrapping up#

Congrats! You’ve gone through 10 JavaScript coding challenges! One of the best things to do when encountering a problem is to use Georges Polya’s practices. Once we understand the problem, we make a plan and try to reiterate an unsolved problem. This way, you are more likely to break down the problem into smaller manageable components.

Solving these problems takes practice. You’ll develop an intuition for algorithms the more time you put into practicing. So don’t worry if it doesn’t come to you right away. Keep practicing!

Educative’s course The Complete Guide to Modern JavaScript walks you through the basics of the language and all the new features introduced up to 2020. After following this course, functions and variables let, const, generators, promises and async won’t be a problem anymore.


Continue reading about JavaScript#


Written By:
Christina Kopecky
 
Join 2.5 million developers at
Explore the catalog

Free Resources