Heim > Java > javaLernprogramm > Wie können wir zwei sortierte Arrays effizient zusammenführen?

Wie können wir zwei sortierte Arrays effizient zusammenführen?

Mary-Kate Olsen
Freigeben: 2024-11-30 12:27:11
Original
1021 Leute haben es durchsucht

How Can We Efficiently Merge Two Sorted Arrays?

Effizientes Zusammenführen sortierter Arrays: Eine verbesserte Methode

Um zwei sortierte Arrays zu einem einzigen sortierten Array zusammenzuführen, können mehrere Programmieransätze verwendet werden. Eine der effizientesten und am häufigsten empfohlenen Techniken ist jedoch die folgende:

Dieser Algorithmus durchläuft beide Arrays gleichzeitig, vergleicht die Elemente an jedem aktuellen Index und hängt das kleinere Element an das Ausgabearray an. Dieser Vorgang wird fortgesetzt, bis eines der Arrays erschöpft ist. Alle verbleibenden Elemente im anderen Array werden dann angehängt.

Hier ist ein Beispiel einer optimierten Implementierung dieses Algorithmus in Java:

public static int[] merge(int[] a, int[] b) {

    int[] answer = new int[a.length + b.length];
    int i = 0, j = 0, k = 0;

    while (i < a.length && j < b.length)
        answer[k++] = a[i] < b[j] ? a[i++] : b[j++];

    while (i < a.length)
        answer[k++] = a[i++];

    while (j < b.length)
        answer[k++] = b[j++];

    return answer;
}
Nach dem Login kopieren

Dieser Ansatz hat eine Zeitkomplexität von O(n m ), wobei n und m die Längen der Arrays a bzw. b darstellen. Diese verbesserte Version eliminiert unnötige Überprüfungen auf Erschöpfung und verwendet eine kompakte While-Schleifenkonstruktion für eine effiziente Zusammenführung.

Das obige ist der detaillierte Inhalt vonWie können wir zwei sortierte Arrays effizient zusammenführen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
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
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage