Tutoriel JAVA
Fichier Java
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é.
É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.
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 :
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 } }
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.
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