"Si un ouvrier veut bien faire son travail, il doit d'abord affûter ses outils." - Confucius, "Les Entretiens de Confucius. Lu Linggong"
Page de garde > La programmation > Trouver la médiane de deux tableaux triés en Java

Trouver la médiane de deux tableaux triés en Java

Publié le 2024-07-30
Parcourir:746

Finding the Median of Two Sorted Arrays in Java

Tutoriel JAVA
Fichier Java

Introduction

Le problème de trouver la médiane de deux tableaux triés est une question classique d'entretien de codage. Le défi est de trouver efficacement la médiane, avec une complexité temporelle de O(log(min(m, n))), où m et n sont les tailles des deux tableaux. Dans cet article, nous présenterons une solution Java qui utilise la recherche binaire pour atteindre cette efficacité.

Énoncé du problème

Étant donné deux tableaux triés nums1 et nums2, trouvez la médiane des deux tableaux triés. La complexité globale de l'exécution doit être O(log(min(m, n))), où m et n sont les tailles des deux tableaux.

Approche

Pour résoudre ce problème, nous utilisons une approche de recherche binaire sur le plus petit des deux tableaux. Le but est de partitionner les deux tableaux de telle sorte que la moitié gauche contienne tous les éléments inférieurs ou égaux aux éléments de la moitié droite. Voici une explication étape par étape :

  1. Assurez-vous que nums1 est le plus petit tableau : pour une recherche binaire plus facile, assurez-vous que nums1 est le plus petit tableau.
  2. Effectuer une recherche binaire : utilisez la recherche binaire sur nums1 pour trouver la partition correcte.
  3. Partitionnement : partitionnez les deux tableaux de telle sorte que le côté gauche contienne des éléments inférieurs et que le côté droit contienne des éléments supérieurs.
  4. Calculer la médiane : en fonction des partitions, calculez la médiane.

Solution

Voici une implémentation Java détaillée de la solution :

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  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
    }
}

Explication

  1. Initialisation : assurez-vous que nums1 est le plus petit tableau.
  2. Recherche binaire : effectuez une recherche binaire sur nums1 pour trouver la partition correcte.
  3. Partitionnement et calcul de la médiane : calculez le maximum des éléments de gauche et le minimum des éléments de droite pour trouver la médiane.

Conclusion

Cette approche de recherche binaire fournit une solution efficace pour trouver la médiane de deux tableaux triés. En tirant parti de la recherche binaire sur le plus petit tableau, la solution atteint une complexité temporelle de O(log(min(m, n))), ce qui la rend adaptée aux grands tableaux d'entrée.

Déclaration de sortie Cet article est reproduit sur : https://dev.to/codeswithpankaj/finding-the-median-of-two-sorted-arrays-in-java-j8h?1 En cas de violation, veuillez contacter [email protected] pour le supprimer
Dernier tutoriel Plus>

Clause de non-responsabilité: Toutes les ressources fournies proviennent en partie d'Internet. En cas de violation de vos droits d'auteur ou d'autres droits et intérêts, veuillez expliquer les raisons détaillées et fournir une preuve du droit d'auteur ou des droits et intérêts, puis l'envoyer à l'adresse e-mail : [email protected]. Nous nous en occuperons pour vous dans les plus brefs délais.

Copyright© 2022 湘ICP备2022001581号-3