> Java > java지도 시간 > Java 배열에서 중복 요소를 효율적으로 제거하는 방법 알아보기

Java 배열에서 중복 요소를 효율적으로 제거하는 방법 알아보기

王林
풀어 주다: 2023-12-23 13:27:58
원래의
1108명이 탐색했습니다.

Java 배열에서 중복 요소를 효율적으로 제거하는 방법 알아보기

인기 있는 프로그래밍 언어인 Java의 배열 작업은 프로그래머의 일상 작업에서 일반적인 작업 중 하나입니다. 배열을 처리할 때 배열에 중복된 요소가 포함되지 않도록 배열의 중복을 제거해야 하는 상황이 자주 발생합니다. 이 기사에서는 빠르고 간결한 여러 가지 Java 배열 중복 제거 방법을 소개하고 구체적인 코드 예제를 제공합니다.

방법 1: HashSet 사용

HashSet은 Java의 컬렉션 유형으로 중복 요소를 허용하지 않는다는 것이 특징입니다. HashSet의 이 기능을 사용하여 배열의 중복을 제거할 수 있습니다. 구체적인 단계는 다음과 같습니다.

public static int[] removeDuplicates(int[] array) {
    HashSet<Integer> set = new HashSet<>();
    for (int value : array) {
        set.add(value);
    }
    int[] result = new int[set.size()];
    int index = 0;
    for (int value : set) {
        result[index++] = value;
    }
    return result;
}
로그인 후 복사

방법 2: Stream 사용
Java 8은 스트리밍 방식으로 컬렉션을 운영하는 방법을 제공하는 Stream API를 도입합니다. Stream의 distinct() 메서드를 사용하여 배열을 빠르게 중복 제거할 수 있습니다. 예는 다음과 같습니다.

public static int[] removeDuplicates(int[] array) {
    return Arrays.stream(array).distinct().toArray();
}
로그인 후 복사

방법 3: 루프 순회 사용
컬렉션과 Streams를 사용하여 배열을 중복 제거하는 것 외에도 기본 루프 순회 방법을 사용할 수도 있습니다. . 어레이 중복 제거를 구현합니다. 구체적인 단계는 다음과 같습니다.

public static int[] removeDuplicates(int[] array) {
    int length = array.length;
    int count = 0;
    for (int i = 0; i < length; i++) {
        boolean isDuplicate = false;
        for (int j = i + 1; j < length; j++) {
            if (array[i] == array[j]) {
                isDuplicate = true;
                break;
            }
        }
        if (!isDuplicate) {
            array[count++] = array[i];
        }
    }
    int[] result = new int[count];
    System.arraycopy(array, 0, result, 0, count);
    return result;
}
로그인 후 복사

요약

이 문서에서는 일반적으로 사용되는 세 가지 Java 배열 중복 제거 방법을 소개하고 구체적인 코드 예제를 제공합니다. HashSet, Stream 또는 기본 루프 탐색을 사용하여 어레이 중복 제거 작업을 빠르고 효과적으로 완료할 수 있습니다. 실제 작업에서는 특정 상황에 따라 배열 중복 제거의 필요성을 처리하는 적절한 방법을 선택하여 코드의 효율성과 가독성을 높일 수 있습니다.

위 내용은 Java 배열에서 중복 요소를 효율적으로 제거하는 방법 알아보기의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿