>Java >java지도 시간 >Java에서 두 목록을 효율적으로 비교하여 공유 요소와 고유 요소를 찾으려면 어떻게 해야 합니까?

Java에서 두 목록을 효율적으로 비교하여 공유 요소와 고유 요소를 찾으려면 어떻게 해야 합니까?

Linda Hamilton
Linda Hamilton원래의
2024-12-03 01:05:13594검색

How Can I Efficiently Compare Two Lists in Java to Find Shared and Unique Elements?

Java 두 목록 비교

두 목록을 비교하여 공유 요소 수를 결정하고 유사 항목과 다른 항목을 모두 식별하는 방법은 다음을 사용하여 수행할 수 있습니다. Java 컬렉션.

공유 요소를 효율적으로 결정하려면 첫 번째 목록에 다음 요소만 포함하도록 수정하는 keepAll 메소드 사용을 고려하세요. 두 목록 모두에 존재하는 요소입니다. 예를 들어 "milan"과 "hafil"이라는 두 개의 목록이 있는 경우, keepAll 작업은 "milan"만 포함하도록 하나의 목록을 수정합니다.

유사한 요소와 다른 요소를 모두 얻으려면 Set을 활용할 수 있습니다. RemoveAll 메소드를 사용하면 목록 간에 공유되지 않는 Set의 모든 요소를 ​​제외할 수 있습니다. 결과 Set에는 유사한 요소가 포함되지만, 두 목록의 합집합을 계산한 후 유사한 요소를 제외하면 다른 요소를 얻을 수 있습니다.

다음은 비교를 위해 Set을 사용하는 샘플 코드 조각입니다.

import java.util.Collection;
import java.util.HashSet;
import java.util.Arrays;

class Repeated {
    public static void main(String[] args) {
        Collection<String> listOne = Arrays.asList("milan", "iga", "dingo", "elpha", "hafil", "meat", "neeta.peeta");
        Collection<String> listTwo = Arrays.asList("hafil", "iga", "binga", "mike", "dingo");

        Collection<String> similar = new HashSet<>(listOne);
        Collection<String> different = new HashSet<>();
        different.addAll(listOne);
        different.addAll(listTwo);

        similar.retainAll(listTwo);
        different.removeAll(similar);

        System.out.printf("One:%s%nTwo:%s%nSimilar:%s%nDifferent:%s%n", listOne, listTwo, similar, different);
    }
}

출력:

One:[milan, iga, dingo, elpha, hafil, meat, neeta.peeta]
Two:[hafil, iga, binga, mike, dingo]
Similar:[dingo, iga, hafil]
Different:[mike, binga, milan, meat, elpha, neeta.peeta]

위 내용은 Java에서 두 목록을 효율적으로 비교하여 공유 요소와 고유 요소를 찾으려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.