Skip to main content

Efficiently Removing Duplicates from Array , ArrayList and List of Employee using Java 8 Streams

 Introduction:

In modern Java programming, streams are a powerful tool for working with collections in a concise and efficient way.

Removing Duplicates from Arrays using Java 8 Streams:

Suppose you have an array of integers with duplicates, and you want to create a new array containing only distinct values then follow below steps

  1. Convert the array into a stream.
  2. Use the distinct() method to eliminate duplicates.
  3. Convert the stream back into an array using toArray().


import java.util.Arrays; public class RemoveDuplicatesFromArray { public static void main(String[] args) { Integer[] array = {1, 2, 2, 3, 4, 4, 5}; // Step 1: Convert the array into a stream. // Step 2: Use the `distinct()` method to eliminate duplicates. // Step 3: Convert the stream back into an array using `toArray()`. Integer[] distinctArray = Arrays.stream(array) .distinct() .toArray(Integer[]::new); System.out.println(Arrays.toString(distinctArray)); } }

Removing Duplicates from ArrayList using Java 8 Streams:

Suppose you have an ArrayList of strings with duplicates, and you want to create a new ArrayList with distinct values then follow below steps

  1. Convert the ArrayList into a stream.
  2. Use the distinct() method to remove duplicates.
  3. Collect the distinct elements into a new ArrayList using Collectors.toList().

import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors; public class RemoveDuplicatesFromArrayList { public static void main(String[] args) { List<String> arrayList = new ArrayList<>(); arrayList.add("apple"); arrayList.add("banana"); arrayList.add("apple"); arrayList.add("cherry"); arrayList.add("banana"); // Step 1: Convert the ArrayList into a stream. // Step 2: Use the `distinct()` method to remove duplicates. // Step 3: Collect the distinct elements into a new ArrayList using `Collectors.toList()`. List<String> distinctList = arrayList.stream() .distinct() .collect(Collectors.toList()); System.out.println(distinctList); } }
  1. Removing Duplicates from List<Employee> using Java 8 Streams:

    1. We convert the List of Employee objects into a stream using stream().
    2. We use the distinct() method to remove duplicates based on the equals() and hashCode() methods defined in the Employee class.
    3. We collect the distinct Employee objects into a new List using Collectors.toList().
    4. The resulting distinctEmployees list will contain only unique Employee objects, and you can iterate through it or perform further operations as needed.

    import java.util.ArrayList; import java.util.List; import java.util.stream.Collectors; public class RemoveDuplicatesFromEmployeeListWithStreams { public static void main(String[] args) { List<Employee> employeeList = new ArrayList<>(); employeeList.add(new Employee(1, "Alice")); employeeList.add(new Employee(2, "Bob")); employeeList.add(new Employee(1, "Alice")); // Duplicate employeeList.add(new Employee(3, "Charlie")); employeeList.add(new Employee(2, "Bob")); // Duplicate // Step 1: Convert the List of employees into a stream. // Step 2: Use the distinct() method to remove duplicates based on equals() and hashCode(). // Step 3: Collect the distinct elements into a new List using Collectors.toList(). List<Employee> distinctEmployees = employeeList.stream() .distinct() .collect(Collectors.toList()); // Print the distinct Employee objects. for (Employee employee : distinctEmployees) { System.out.println(employee.getId() + ": " + employee.getName()); } } }


    Comments

    Popular posts from this blog

    Using Java 8 Streams to Find the Second-Highest Salary in an Employee List

    To find the second-highest salary from a list of employees using Java 8 streams, you can follow these steps: Create a list of employees with their salaries. Use Java 8 streams to sort the employees by salary in descending order. Skip the first element (which is the employee with the highest salary). Get the first element of the remaining stream (which is the employee with the second-highest salary). Example code: java import java.util.ArrayList; import java.util.List; class Employee { private String name; private double salary; public Employee (String name, double salary) { this .name = name; this .salary = salary; } public double getSalary () { return salary; } } public class SecondHighestSalary { public static void main (String[] args) { List<Employee> employees = new ArrayList <>(); employees.add( new Employee ( "John" , 60000.0 )); employees.add( new Employe...

    Java Data Structures and Algorithms: A Practical Guide with Examples and Top Interview Questions"

    Data Structures and Algorithms in Java Understanding Data Structures ArrayList When to Use: Use ArrayList when you need a dynamic array that can grow or shrink in size. It's efficient for random access but less efficient for frequent insertions and deletions. Example Code: java List<String> arrayList = new ArrayList <>(); arrayList.add( "Java" ); arrayList.add( "Data Structures" ); arrayList.add( "Algorithms" ); LinkedList When to Use: LinkedList is suitable for frequent insertions and deletions. It provides better performance than ArrayList in scenarios where elements are frequently added or removed from the middle of the list. Example Code: java LinkedList<String> linkedList = new LinkedList <>(); linkedList.add( "Java" ); linkedList.add( "Data Structures" ); linkedList.add( "Algorithms" ); HashMap When to Use: Use HashMap for fast retrieval of data based on a key. It is efficient for loo...

    Object-Oriented Programming (OOP) Concepts in Java

      Introduction: Object-Oriented Programming (OOP) is a paradigm that has revolutionized software development by organizing code around real-world entities and their interactions. For experienced developers aiming to excel in Java interviews, a solid understanding of OOP concepts is essential. In this blog post, we will delve into key OOP principles with real-time examples and provide sample Java code to reinforce your knowledge. 1. Encapsulation: Encapsulation is the bundling of data (attributes) and methods (functions) that operate on the data into a single unit, known as a class. The internal details of the class are hidden from the outside, and only a public interface is exposed. Real-time Example: Consider a Person class: java public class Person { private String name; private int age; public Person (String name, int age) { this .name = name; this .age = age; } public String getName () { return name; } public ...

    Subscribe to get new posts

    Name

    Email *

    Message *