Remove repeated elements from ArrayList in Java

Prerequisite: ArrayList in Java
Given an ArrayList, the task is to remove repeated elements of the ArrayList in Java.
Examples:
Input: ArrayList = [1, 2, 2, 3, 4, 4, 4] Output: [1, 2, 3, 4] Input: ArrayList = [12, 23, 23, 34, 45, 45, 45, 45, 57, 67, 89] Output: [12, 23, 34, 45, 57, 67, 89]
Below are the various methods to remove repeated elements an ArrayList in Java:
- Using a Set: Since Set is a collection which do not includes any duplicate elements. Hence the solution can be achieved with the help of a Set.
Approach:
- Get the ArrayList with repeated elements.
- Convert the ArrayList to Set.
- Now convert the Set back to ArrayList. This will remove all the repeated elements.
Below is the implementation of the above approach:
// Java code to illustrate remove duolicate// of ArrayList using hashSet<> methodimportjava.util.*;publicclassGFG {publicstaticvoidmain(String args[]){// create a ArrayList String typeArrayList<String>gfg =newArrayList<String>();// Initialize an ArrayListgfg.add("Geeks");gfg.add("for");gfg.add("Geeks");// print ArrayListSystem.out.println("Original ArrayList : "+ gfg);// -----Using LinkedHashSet-----System.out.println("\nUsing LinkedHashSet:\n");// create a set and copy all value of listSet<String> set =newLinkedHashSet<>(gfg);// create a list and copy all value of setList<String> gfg1 =newArrayList<>(set);// print ArrayListSystem.out.println("Modified ArrayList : "+ gfg1);// -----Using HashSet-----System.out.println("\nUsing HashSet:\n");// create a set and copy all value of listSet<String> set1 =newHashSet<>(gfg);// create a list and copy all value of setList<String> gfg2 =newArrayList<>(set);// print ArrayListSystem.out.println("Modified ArrayList : "+ gfg2);}}Output:Original ArrayList : [Geeks, for, Geeks] Using LinkedHashSet: Modified ArrayList : [Geeks, for] Using HashSet: Modified ArrayList : [Geeks, for]
- Using Java 8 Lambdas:
Approach:
- Get the ArrayList with repeated elements.
- Convert the ArrayList to Stream using stream() method.
- Set the filter condition to be distinct using distinct() method.
- Collect the filtered values as List using collect() method. This list will be with repeated elements removed
Below is the implementation of the above approach:
Example:
// Java code to illustrate remove duolicate// of ArrayList using hashSet<> methodimportjava.util.*;importjava.util.stream.Collectors;publicclassGFG {publicstaticvoidmain(String args[]){// create a ArrayList String typeArrayList<String>gfg =newArrayList<String>();// Initialize an ArrayListgfg.add("Geeks");gfg.add("for");gfg.add("Geeks");// print ArrayListSystem.out.println("Original ArrayList : "+ gfg);// create a list and copy all distinct value of listList<String> gfg1 = gfg.stream().distinct().collect(Collectors.toList());// print modified listSystem.out.println("Modified List : "+ gfg1);}}Output:Original ArrayList : [Geeks, for, Geeks] Modified List : [Geeks, for]



