Heim >Java >javaLernprogramm >Wie kann ich zwei Listen in Java effizient vergleichen, um sowohl gemeinsame als auch unterschiedliche Elemente zu finden?

Wie kann ich zwei Listen in Java effizient vergleichen, um sowohl gemeinsame als auch unterschiedliche Elemente zu finden?

DDD
DDDOriginal
2024-12-01 01:09:15652Durchsuche

How Can I Efficiently Compare Two Lists in Java to Find Both Common and Different Elements?

Vergleich zweier Listen in Java

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!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn