Practice Program: remove duplicates from an array

Write a Java program to remove duplicates from an array.

This Java program efficiently removes duplicate elements from an array using the Arrays.stream() and distinct() methods, which are part of the Java Streams API introduced in Java 8. Here’s an explanation of how it works:

import java.util.Arrays;
class Main {
    public static void main(String[] args) {
        int[] arr = {3, 3, 6, 7, 8, 9, 9};
        int[] result = removeDuplicate(arr);
        System.out.print("After remove duplicate array is: " + Arrays.toString(result));
    }

    public static int[] removeDuplicate(int[] arr) {
        return Arrays.stream(arr).distinct().toArray();
    }
}

Output:

After remove duplicate array is: [3, 6, 7, 8, 9]

How It Works

  1. Input Array:
    • The input array, arr, is {3, 3, 6, 7, 8, 9, 9}.
  2. Stream Conversion:
    • Arrays.stream(arr) converts the array to a stream, enabling functional-style operations.
  3. Removing Duplicates:
    • The .distinct() method ensures only unique elements remain in the stream.
  4. Conversion Back to Array:
    • .toArray() collects the unique elements into a new array.
  5. Output:
    • The result is an array with duplicates removed.

Advantages

  1. Simplicity:
    • The code is concise and leverages Java’s Streams API to handle duplicates efficiently.
  2. Performance:
    • The .distinct() method uses hashing internally, providing good performance for moderately sized arrays.
  3. Readability:
    • Functional-style programming makes the logic straightforward and readable.

Edge Cases

  1. Empty Array:
    • Input: arr = {}
    • Output: After remove duplicate array is: []
  2. Array Without Duplicates:
    • Input: arr = {1, 2, 3}
    • Output: After remove duplicate array is: [1, 2, 3]
  3. All Elements Are Duplicates:
    • Input: arr = {5, 5, 5}
    • Output: After remove duplicate array is: [5]
  4. Negative Numbers and Zero:
    • Input: arr = {-1, 0, -1, 0, 1}
    • Output: After remove duplicate array is: [-1, 0, 1]

Limitations

  • For extremely large arrays, memory usage could be a concern since a stream pipeline is created.

Leave a Reply