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 중국어 웹사이트의 기타 관련 기사를 참조하세요!