Heim Java javaLernprogramm Ermitteln des Medians zweier sortierter Arrays in Java

Ermitteln des Medians zweier sortierter Arrays in Java

Jul 22, 2024 pm 05:46 PM

Finding the Median of Two Sorted Arrays in Java

JAVA-Tutorial
Java-Datei

Einführung

Das Problem, den Median zweier sortierter Arrays zu finden, ist eine klassische Frage in Codierungsinterviews. Die Herausforderung besteht darin, den Median effizient mit einer Zeitkomplexität von O(log(min(m, n))) zu finden, wobei m und n die Größen der beiden Arrays sind. In diesem Artikel gehen wir eine Java-Lösung durch, die eine binäre Suche verwendet, um diese Effizienz zu erreichen.

Problemstellung

Bestimmen Sie anhand zweier sortierter Arrays nums1 und nums2 den Median der beiden sortierten Arrays. Die gesamte Laufzeitkomplexität sollte O(log(min(m, n))) betragen, wobei m und n die Größen der beiden Arrays sind.

Ansatz

Um dieses Problem zu lösen, verwenden wir einen binären Suchansatz für das kleinere der beiden Arrays. Das Ziel besteht darin, beide Arrays so zu unterteilen, dass die linke Hälfte alle Elemente enthält, die kleiner oder gleich den Elementen in der rechten Hälfte sind. Hier ist eine Schritt-für-Schritt-Erklärung:

  1. Stellen Sie sicher, dass nums1 das kleinere Array ist: Stellen Sie für eine einfachere binäre Suche sicher, dass nums1 das kleinere Array ist.
  2. Binäre Suche durchführen: Verwenden Sie die binäre Suche auf nums1, um die richtige Partition zu finden.
  3. Partitionierung: Partitionieren Sie beide Arrays so, dass die linke Seite niedrigere Elemente und die rechte Seite höhere Elemente enthält.
  4. Median berechnen: Berechnen Sie basierend auf den Partitionen den Median.

Lösung

Hier ist eine detaillierte Java-Implementierung der Lösung:

public class MedianOfTwoSortedArrays {
    public double findMedianSortedArrays(int[] nums1, int[] nums2) {
        // Ensure nums1 is the smaller array
        if (nums1.length > nums2.length) {
            int[] temp = nums1;
            nums1 = nums2;
            nums2 = temp;
        }

        int x = nums1.length;
        int y = nums2.length;
        int low = 0, high = x;

        while (low <= high) {
            int partitionX = (low + high) / 2;
            int partitionY = (x + y + 1) / 2 - partitionX;

            // Edge cases
            int maxX = (partitionX == 0) ? Integer.MIN_VALUE : nums1[partitionX - 1];
            int minX = (partitionX == x) ? Integer.MAX_VALUE : nums1[partitionX];
            int maxY = (partitionY == 0) ? Integer.MIN_VALUE : nums2[partitionY - 1];
            int minY = (partitionY == y) ? Integer.MAX_VALUE : nums2[partitionY];

            if (maxX <= minY && maxY <= minX) {
                // Correct partition
                if ((x + y) % 2 == 0) {
                    return (Math.max(maxX, maxY) + Math.min(minX, minY)) / 2.0;
                } else {
                    return Math.max(maxX, maxY);
                }
            } else if (maxX > minY) {
                high = partitionX - 1;
            } else {
                low = partitionX + 1;
            }
        }

        throw new IllegalArgumentException("Input arrays are not sorted");
    }

    public static void main(String[] args) {
        MedianOfTwoSortedArrays solution = new MedianOfTwoSortedArrays();

        int[] nums1 = {1, 3};
        int[] nums2 = {2};
        System.out.println("Median: " + solution.findMedianSortedArrays(nums1, nums2)); // Output: 2.0

        int[] nums1_2 = {1, 2};
        int[] nums2_2 = {3, 4};
        System.out.println("Median: " + solution.findMedianSortedArrays(nums1_2, nums2_2)); // Output: 2.5
    }
}
Nach dem Login kopieren

Erläuterung

  1. Initialisierung: Stellen Sie sicher, dass nums1 das kleinere Array ist.
  2. Binäre Suche: Führen Sie eine binäre Suche auf nums1 durch, um die richtige Partition zu finden.
  3. Partitionierung und Medianberechnung: Berechnen Sie das Maximum der linken Elemente und das Minimum der rechten Elemente, um den Median zu ermitteln.

Abschluss

Dieser binäre Suchansatz bietet eine effiziente Lösung zum Ermitteln des Medians zweier sortierter Arrays. Durch die Nutzung der binären Suche auf dem kleineren Array erreicht die Lösung eine Zeitkomplexität von O(log(min(m, n))), wodurch sie für große Eingabearrays geeignet ist.

Das obige ist der detaillierte Inhalt vonErmitteln des Medians zweier sortierter Arrays in Java. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

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

Heiße Artikel -Tags

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

Top 4 JavaScript -Frameworks in 2025: React, Angular, Vue, Svelte

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle? Mar 17, 2025 pm 05:35 PM

Wie funktioniert der Klassenladungsmechanismus von Java, einschließlich verschiedener Klassenloader und deren Delegationsmodelle?

Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung? Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung? Mar 17, 2025 pm 05:46 PM

Wie benutze ich Maven oder Gradle für das fortschrittliche Java -Projektmanagement, die Erstellung von Automatisierung und Abhängigkeitslösung?

Node.js 20: wichtige Leistungssteigerung und neue Funktionen Node.js 20: wichtige Leistungssteigerung und neue Funktionen Mar 07, 2025 pm 06:12 PM

Node.js 20: wichtige Leistungssteigerung und neue Funktionen

ICEBERG: Die Zukunft von Data Lake Tabellen ICEBERG: Die Zukunft von Data Lake Tabellen Mar 07, 2025 pm 06:31 PM

ICEBERG: Die Zukunft von Data Lake Tabellen

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache? Mar 17, 2025 pm 05:44 PM

Wie implementiere ich mehrstufige Caching in Java-Anwendungen mit Bibliotheken wie Koffein oder Guava-Cache?

Wie kann ich funktionale Programmierungstechniken in Java implementieren? Wie kann ich funktionale Programmierungstechniken in Java implementieren? Mar 11, 2025 pm 05:51 PM

Wie kann ich funktionale Programmierungstechniken in Java implementieren?

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben Mar 07, 2025 pm 05:52 PM

Spring Boot Snakeyaml 2.0 CVE-2022-1471 Problem behoben

See all articles