So first of all, I am not expecting a specific solution to my problem, but instead some insights from more experienced developers that could enlighten me and put me on the right track. As I am not yet experienced enough in algorithms and data structures and I take this as a challenge for myself.
I have n number of arrays, where n >= 2. They all contain objects and in the end, I want an array that contains only the common elements between all these arrays.
array1 = [{ id: 1 }, { id: 2 }, { id: 6 }, { id: 10 }]
array2 = [{ id: 2 }, { id: 4 }, { id: 10 }]
array3 = [{ id: 2 }, { id: 3 }, { id: 10 }]
arrayOfArrays = [array1, array2, array3]
intersect = [{ id: 2 }, { id: 10 }]
How would one approach this problem? I have read solutions using Divide And Conquer, or Hash tables, and even using the lodash library but I would like to implement my own solution for once and not rely on anything external, and at the same time practice algorithms.
SetorMap.idthat matched, but one also had anamekey that didn't match, would you still keep theidor that would mean they don't match.SetandMapUnfortunately, I receive the arrays unsorted my bad I should've made this clear in my example. I guess I could potentially sort all of them first but that would add more computing @ToddSkelton I wanna say key value pairs. An object with the id 240 would always contain the same exact data, I pull these arrays from an api.