w3resource

JavaScript: Get the symmetric difference between two given arrays, after applying the provided function to each array element of both

JavaScript: Exercise-133 with Solution

Symmetric Difference with Mapping

Write a JavaScript program to get the symmetric difference between two given arrays, after applying the provided function to each array element of both.

  • Create a new Set() from each array to get the unique values of each one after applying fn to them.
  • Use Array.prototype.filter() on each of them to only keep values not contained in the other.

Sample Solution:

JavaScript Code:

//#Source https://bit.ly/2neWfJ2

// Define the 'symmetricDifferenceBy' function.
const symmetricDifferenceBy = (a, b, fn) => {
  // Create sets of mapped values from arrays 'a' and 'b'.
  const sA = new Set(a.map(v => fn(v))),
    sB = new Set(b.map(v => fn(v)));
  // Return the symmetric difference by filtering elements that are unique to each array.
  return [...a.filter(x => !sB.has(fn(x))), ...b.filter(x => !sA.has(fn(x)))];
};

// Test the 'symmetricDifferenceBy' function.
console.log(symmetricDifferenceBy([2.1, 1.2], [2.3, 3.4], Math.floor)); // Output: [1.2, 3.4]

Output:

[1.2,3.4]

Flowchart:

flowchart: Get the symmetric difference between two given arrays, after applying the provided function to each array element of both

Live Demo:

See the Pen javascript-basic-exercise-133-1 by w3resource (@w3resource) on CodePen.


Improve this sample solution and post your code through Disqus

Previous: Write a JavaScript program to get the symmetric difference between two given arrays, using a provided function as a comparator.
Next: Write a JavaScript program to get the symmetric difference between two given arrays.

What is the difficulty level of this exercise?

Test your Programming skills with w3resource's quiz.



Become a Patron!

Follow us on Facebook and Twitter for latest update.

It will be nice if you may share this link in any developer community or anywhere else, from where other developers may find this content. Thanks.

https://www.w3resource.com/javascript-exercises/fundamental/javascript-fundamental-exercise-133.php