Java에서 두 목록 비교
공유하는 요소 수를 확인하기 위해 비교하려는 두 개의 데이터 세트가 있습니다. 이것이 Java List 객체가 아니라고 가정하면 다음 접근 방식을 고려하십시오.
ArrayList 사용
ArrayList를 활용하면 keepAll 메소드를 사용할 수 있습니다. 이 방법은 두 번째 목록에도 있는 첫 번째 목록의 요소만 보존합니다. 예:
import java.util.Collection; import java.util.ArrayList; import java.util.Arrays; public class ListComparison { public static void main(String[] args) { Collection<String> listOne = new ArrayList<>(Arrays.asList("milan", "dingo", "elpha", "hafil", "meat", "iga", "neeta.peeta")); Collection<String> listTwo = new ArrayList<>(Arrays.asList("hafil", "iga", "binga", "mike", "dingo")); listOne.retainAll(listTwo); System.out.println(listOne); } }
이 코드는 listOne과 listTwo 사이의 공통 요소 목록을 인쇄합니다.
HashSet 사용
원하는 경우 반복되는 값(즉, 두 목록에 여러 번 나타나는 요소)을 포함하려면 대신 HashSet을 사용할 수 있습니다. ArrayList. HashSet은 중복을 허용하지 않으므로 비교 후 RemoveAll 메서드를 사용하여 두 목록의 결합된 요소 집합에서 공통 요소를 제거할 수 있습니다. 그러면 고유한 비공통 요소 목록이 제공됩니다.
import java.util.Collection; import java.util.HashSet; import java.util.Arrays; public class ListComparison { public static void main(String[] args) { Collection<String> listOne = Arrays.asList("milan", "iga", "dingo", "iga", "elpha", "iga", "hafil", "iga", "meat", "iga", "neeta.peeta", "iga"); Collection<String> listTwo = Arrays.asList("hafil", "iga", "binga", "mike", "dingo", "dingo", "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); } }
이 수정된 코드는 두 목록 사이의 유사 요소와 다른 요소를 출력합니다.
위 내용은 Java에서 두 목록을 효율적으로 비교하고 공통 요소와 고유 요소를 찾으려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!