How to Remove Duplicates from ArrayList in Java
Given an ArrayList with duplicate values, the task is to remove the duplicate values from this ArrayList in Java.
Examples:
Input: List = [1, 10, 2, 2, 10, 3, 3, 3, 4, 5, 5] Output: List = [1, 10, 2, 3, 4, 5] Input: List = ["G", "e", "e", "k", "s"] Output: List = ["G", "e", "k", "s"]
Using Iterator
Approach:- Get the ArrayList with duplicate values.
- Create another ArrayList.
- Traverse through the first arraylist and store the first appearance of each element into the second arraylist using contains() method.
- The second ArrayList contains the elements with duplicates removed.
Below is the implementation of the above approach:Output:
ArrayList with duplicates: [1, 10, 1, 2, 2, 3, 3, 10, 3, 4, 5, 5] ArrayList with duplicates removed: [1, 10, 2, 3, 4, 5]
Using LinkedHashSet
A better way (both time complexity and ease of implementation wise) is to remove duplicates from an ArrayList is to convert it into a Set that does not allow duplicates. Hence LinkedHashSet is the best option available as this do not allows duplicates as well it preserves the insertion order.Approach:- Get the ArrayList with duplicate values.
- Create a LinkedHashSet from this ArrayList. This will remove the duplicates
- Convert this LinkedHashSet back to Arraylist.
- The second ArrayList contains the elements with duplicates removed.
Below is the implementation of the above approach:Output:
ArrayList with duplicates: [1, 10, 1, 2, 2, 3, 10, 3, 3, 4, 5, 5] ArrayList with duplicates removed: [1, 10, 2, 3, 4, 5]
Using Java 8 Stream.distinct()
You can use the distinct() method from the Stream API. The distinct() method return a new Stream without duplicates elements based on the result returned by equals() method, which can be used for further processing. The actual processing of Stream pipeline starts only after calling terminal methods like forEach() or collect().Approach:- Get the ArrayList with duplicate values.
- Create a new List from this ArrayList.
- Using Stream().distinct() method which return distinct object stream.
- convert this object stream into List
Below is the implementation of the above approach:Output:
ArrayList with duplicates: [1, 10, 1, 2, 2, 3, 10, 3, 3, 4, 5, 5] ArrayList with duplicates removed: [1, 10, 2, 3, 4, 5]
Recommended Posts:
- Remove all elements from the ArrayList in Java
- How to remove an element from ArrayList in Java?
- Remove repeated elements from ArrayList in Java
- ArrayList and LinkedList remove() methods in Java with Examples
- ArrayList of ArrayList in Java
- Java.util.ArrayList.addall() method in Java
- ArrayList in Java
- Arraylist.contains() in Java
- Java.util.ArrayList.add() Method in Java
- Java.util.Arraylist.indexOf() in Java
- ArrayList isEmpty() in Java with example
- ArrayList trimToSize() in Java with example
- Initialize an ArrayList in Java
- Array of ArrayList in Java
- ArrayList vs LinkedList in Java
No comments:
Post a Comment