In Java kann der Vergleich zweier Listen durch verschiedene Methoden und Datenstrukturen erreicht werden. In diesem Artikel werden verschiedene Ansätze zum Vergleichen von Listen untersucht, wobei der Schwerpunkt auf der Suche nach ähnlichen und unterschiedlichen Elementen liegt.
ArrayList- und RetainAll-Methode
Die Verwendung einer ArrayList und der RetainAll-Methode ermöglicht Ihnen Folgendes Behalten Sie nur die Elemente bei, die in beiden Listen enthalten sind.
import java.util.Collection; import java.util.ArrayList; public class ListComparison { public static void main(String[] args) { Collection<String> list1 = new ArrayList<>(Arrays.asList("milan", "dingo", "elpha", "hafil", "meat", "iga", "neeta.peeta")); Collection<String> list2 = new ArrayList<>(Arrays.asList("hafil", "iga", "binga", "mike", "dingo")); list1.retainAll(list2); System.out.println("Common elements: " + list1); } }
HashSet und RemoveAll Methode
Wenn Sie nicht nur gemeinsame, sondern auch unterschiedliche Elemente finden müssen, ist die Verwendung eines HashSets und der Methode „removeAll“ ein geeigneter Ansatz. Ein HashSet lässt keine Duplikate zu und kann daher wiederholte Werte eliminieren.
import java.util.Collection; import java.util.HashSet; public class ListComparison2 { public static void main(String[] args) { Collection<String> list1 = Arrays.asList("milan", "iga", "dingo", "iga", "elpha", "iga", "hafil", "iga", "meat", "iga", "neeta.peeta", "iga"); Collection<String> list2 = Arrays.asList("hafil", "iga", "binga", "mike", "dingo", "dingo", "dingo"); Collection<String> common = new HashSet<>(list1); Collection<String> different = new HashSet<>(); different.addAll(list1); different.addAll(list2); common.retainAll(list2); different.removeAll(common); System.out.printf("Common elements: %s%nDifferent elements: %s%n", common, different); } }
Benutzerdefinierter Ansatz
Alternativ können Sie eine benutzerdefinierte Methode erstellen, um die Listen zu vergleichen und Gibt die gemeinsamen und unterschiedlichen Elemente zurück. Dies bietet mehr Flexibilität und Anpassungsmöglichkeiten.
public class CustomListComparison { public static void main(String[] args) { List<String> list1 = Arrays.asList("milan", "dingo", "elpha", "hafil", "meat", "iga", "neeta.peeta"); List<String> list2 = Arrays.asList("hafil", "iga", "binga", "mike", "dingo"); List<String> common = new ArrayList<>(); List<String> different = new ArrayList<>(); for (String element : list1) { if (list2.contains(element)) { common.add(element); } else { different.add(element); } } for (String element : list2) { if (!list1.contains(element)) { different.add(element); } } System.out.printf("Common elements: %s%nDifferent elements: %s%n", common, different); } }
Durch die Nutzung dieser Techniken können Sie zwei Listen in Java effizient vergleichen und dabei sowohl die gemeinsamen als auch die unterschiedlichen Elemente identifizieren
Das obige ist der detaillierte Inhalt vonWie kann ich zwei Listen in Java effizient vergleichen, um sowohl gemeinsame als auch unterschiedliche Elemente zu finden?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!