Recursive Array Permutations in JavaScript

JavaScriptJavaScriptBeginner
Practice Now

This tutorial is from open-source community. Access the source code

Introduction

In this lab, we will explore the concept of array permutations in JavaScript. We will learn how to use recursion to generate all possible permutations of an array's elements, even if they contain duplicates. We will also understand how to use Array methods such as map() and reduce() to combine the different permutations into a single array. However, we must keep in mind that executing this function on arrays with more than 8 to 10 elements may significantly increase the execution time and cause the browser to hang.


Skills Graph

%%%%{init: {'theme':'neutral'}}%%%% flowchart RL javascript(("`JavaScript`")) -.-> javascript/BasicConceptsGroup(["`Basic Concepts`"]) javascript(("`JavaScript`")) -.-> javascript/AdvancedConceptsGroup(["`Advanced Concepts`"]) javascript/BasicConceptsGroup -.-> javascript/cond_stmts("`Conditional Statements`") javascript/BasicConceptsGroup -.-> javascript/array_methods("`Array Methods`") javascript/BasicConceptsGroup -.-> javascript/obj_manip("`Object Manipulation`") javascript/AdvancedConceptsGroup -.-> javascript/higher_funcs("`Higher-Order Functions`") javascript/AdvancedConceptsGroup -.-> javascript/spread_rest("`Spread and Rest Operators`") javascript/BasicConceptsGroup -.-> javascript/variables("`Variables`") javascript/BasicConceptsGroup -.-> javascript/data_types("`Data Types`") javascript/BasicConceptsGroup -.-> javascript/arith_ops("`Arithmetic Operators`") javascript/BasicConceptsGroup -.-> javascript/comp_ops("`Comparison Operators`") subgraph Lab Skills javascript/cond_stmts -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/array_methods -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/obj_manip -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/higher_funcs -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/spread_rest -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/variables -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/data_types -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/arith_ops -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} javascript/comp_ops -.-> lab-28151{{"`Recursive Array Permutations in JavaScript`"}} end

How to Generate All Array Permutations

To start practicing coding, open the Terminal/SSH and type node.

Here's an algorithm that generates all permutations of an array's elements (even if it contains duplicates). Follow these steps to implement it:

  1. Use recursion.
  2. For each element in the given array, create all the partial permutations for the rest of its elements.
  3. Use Array.prototype.map() to combine the element with each partial permutation, then Array.prototype.reduce() to combine all permutations in one array.
  4. The base cases are for arrays with a length of 2 or 1.
  5. Beware that this function's execution time increases exponentially with each array element. Anything more than 8 to 10 entries may cause your browser to hang as it tries to solve all the different combinations.

Here's the code:

const permutations = (arr) => {
  if (arr.length <= 2) return arr.length === 2 ? [arr, [arr[1], arr[0]]] : arr;
  return arr.reduce(
    (acc, item, i) =>
      acc.concat(
        permutations([...arr.slice(0, i), ...arr.slice(i + 1)]).map((val) => [
          item,
          ...val
        ])
      ),
    []
  );
};

You can test the code by calling the permutations() function with an array argument:

permutations([1, 33, 5]);
// [ [1, 33, 5], [1, 5, 33], [33, 1, 5], [33, 5, 1], [5, 1, 33], [5, 33, 1] ]

Summary

Congratulations! You have completed the Array Permutations lab. You can practice more labs in LabEx to improve your skills.

Other JavaScript Tutorials you may like