You have very big list of elements. Please provide best solution to detect and remove duplicated elements.
Please provide a solution and comments about its benefits and drawbacks. Please give us complexity (O(n)
, O(n^2)
, O(ln(n))
, ...). Please think about custom classes like:
class Person {
String name;
int age;
}
You can check contest bye-laws here.
Check out our Confitura 2015 site here
We are hiring! Visit our career site.
Provided 3 solutions:
-
O(n^2) - just take elements one by one and remove all the other occurrences from the rest of the list
-
O(n) - using additional space for hashtable allocation. The algorithm is fairly simple:
- take the head
- check whether hashtable contains
- if yes then drop this element and continue with tail
- if no add head to the result list and continue with tail
-
O(n*log(n)) - average - the third one with the quick sort is not stable because the resulting list will be sorted so most probably not the same as the expected one. But the solution may be acceptable in some cases
When it comes to the custom classes - the example in duplicates.people
shows that scala case classes provide it out of the box - because of equals
and hashCode
.