Maison > Java > javaDidacticiel > Explication détaillée des exemples de méthodes pour implémenter l'algorithme de tri par fusion en Java

Explication détaillée des exemples de méthodes pour implémenter l'algorithme de tri par fusion en Java

黄舟
Libérer: 2017-09-23 09:58:22
original
1915 Les gens l'ont consulté

Cet article présente principalement des informations pertinentes sur l'explication détaillée de l'algorithme de tri par fusion en Java. L'algorithme de tri par fusion est également appelé algorithme de tri par fusion avec une complexité temporelle de O(N logN). , il est utilisé dans la vie quotidienne. Les amis qui en ont besoin peuvent se référer à

Explication détaillée de l'algorithme de tri par fusion en Java

Le. L'algorithme de tri par fusion, comme son nom l'indique, est une méthode qui divise d'abord puis combine. L'idée de l'algorithme est de décomposer le tableau à trier en éléments individuels, chaque élément est un seul individu, puis de trier les deux éléments adjacents du plus petit au plus petit. grand ou de grand à petit pour former un tout. Chaque tout contient un ou deux éléments, puis continuez à « fusionner » les touts adjacents. Parce que chaque tout est trié, un certain algorithme peut être utilisé pour les fusionner. chaque tout contient trois éléments. Après avoir atteint quatre éléments, continuez à fusionner les touts adjacents jusqu'à ce que tous les touts soient fusionnés en un seul tout. Le tout final est le résultat du tri du tableau d'origine.

Pour les touts adjacents, l'idée de​​fusionner est de prendre le plus petit élément des deux touts (en supposant qu'ils soient effectivement triés par ordre croissant) et de le placer dans un nouveau tableau à chaque fois, puis parcourez-le, et enfin les deux touts. Une fois tous les éléments pris, un tout trié par ordre croissant sera obtenu. Le processus de fusion revient à avoir deux jeux A et B classés par ordre croissant (comme le montre la figure). Chaque fois qu'un élément est pris du haut et placé dans le jeu C :

<.> On peut voir sur l'image que pour deux entiers adjacents A et B, les éléments à l'intérieur sont triés par ordre croissant. Il y a maintenant un tableau temporaire C, puis les deux éléments en haut de A et B comparent, retirez le plus petit élément et placez-le dans C. Pour tout l'élément retiré, déplacez l'indice pointant vers l'élément vers le bas d'un bit. Continuez à retirer le plus petit des éléments supérieurs des deux touts et placez-le dans C, et boucle en séquence, lorsque les éléments d'un certain tout sont récupérés, tous les éléments de l'autre tout sont directement déplacés vers C. Pour l'ensemble C, il s'obtient en triant A et B. Puisque A et B sont deux touts adjacents, au final, il suffit de copier les éléments de C dans un tout commun composé de A et B. Autrement dit, cela permet également d'atteindre l'objectif de fusionner A et B et de les trier en même temps.

Voici l'algorithme spécifique du tri par fusion :


public class MergeSort {
 public static <AnyType extends Comparable<? super AnyType>> void mergeSort(AnyType[] arr) {
  AnyType[] tmp = ((AnyType[]) new Comparable[arr.length]);
  mergeSort(arr, 0, arr.length - 1, tmp);
 }

 private static <AnyType extends Comparable<? super AnyType>> void mergeSort(AnyType[] arr, int start, int end, AnyType[] tmp) {
  if (start < end) {
   int mid = (start + end) >> 1;
   mergeSort(arr, start, mid, tmp);
   mergeSort(arr, mid + 1, end, tmp);
   merge(arr, start, mid, end, tmp);
  }
 }

 private static <AnyType extends Comparable<? super AnyType>> void merge(AnyType[] arr, int start, int mid, int end, AnyType[] tmp) {
  int i = start, j = mid + 1, k = start;
  while (i <= mid && j <= end) {
   if (arr[i].compareTo(arr[j]) < 0) {
    tmp[k++] = arr[i++];
   } else {
    tmp[k++] = arr[j++];
   }
  }

  while (i <= mid) {
   tmp[k++] = arr[i++];
  }

  while (j <= end) {
   tmp[k++] = arr[j++];
  }

  for (int m = start; m <= end; m++) {
   arr[m] = tmp[m];
  }
 }
}
Copier après la connexion
Il existe deux méthodes principales dans le code


private static <AnyType extends Comparable<? super AnyType>> void mergeSort(AnyType[] arr, int start, int end, AnyType[] tmp)
Copier après la connexion


private static <AnyType extends Comparable<? super AnyType>> void merge(AnyType[] arr, int start, int mid, int end, AnyType[] tmp)
Copier après la connexion
La première méthode est une méthode récursive

Pour la méthode récursive, la fonction de la méthode doit être clairement définie Voici. la récursivité Le but de la méthode est de trier les éléments entre le début et la fin du tableau entrant, et tmp est un tableau auxiliaire. Dans l'implémentation spécifique de cette méthode, on peut voir que l'idée est de continuer d'appeler la récursion pour trier les éléments entre le début et le milieu, puis d'appeler la récursivité pour trier les éléments entre le milieu et la fin. Après ces deux méthodes, les éléments. du début au milieu et du milieu à la fin sont triés, et la deuxième méthode doit être appelée à ce moment.

La fonction de la deuxième méthode est de fusionner les deux parties triées

Pour la première méthode, la dernière étape consiste à exécuter la deuxième méthode, qui consiste à trier les deux étapes précédentes. Après avoir fusionné les pièces, la fonction de cette méthode est terminée. Pour la deuxième méthode, l'idée de mise en œuvre est la même que celle décrite précédemment. Prenez le plus petit élément du haut des deux piles de cartes et placez-le dans un tableau temporaire. Lorsqu'une pile de cartes est retirée, placez les éléments restants. le tableau dans le deuxième deck, remet enfin les éléments du tableau temporaire dans le tableau d'origine. Cet article explique principalement l'idée du tri par fusion en détail et analyse le code en fonction d'un code et d'idées spécifiques.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal