Maison > Java > javaDidacticiel > Évaluation de l'efficacité et des performances de Java Quick Sort

Évaluation de l'efficacité et des performances de Java Quick Sort

王林
Libérer: 2024-02-19 22:16:07
original
739 Les gens l'ont consulté

Évaluation de lefficacité et des performances de Java Quick Sort

Analyse et comparaison des performances de Java Quick Sort

Quick Sort (Quick Sort) est un algorithme de tri basé sur la comparaison qui est largement utilisé dans le développement réel en raison de sa vitesse d'exécution rapide et de ses bonnes performances. Cet article effectuera une analyse des performances de l'algorithme de tri rapide en Java et le comparera avec d'autres algorithmes de tri courants.

  1. Principe de l'algorithme de tri rapide
    Le tri rapide adopte l'idée de​​la méthode diviser pour régner. En divisant les données à trier en deux parties indépendantes, les sous-séquences gauche et droite sont triées de manière récursive, de manière à obtenir un résultat. le but de commander la séquence entière. Les étapes spécifiques de l'algorithme sont les suivantes :
    1) Sélectionnez une valeur d'axe (Pivot) dans le tableau, généralement le premier élément du tableau.
    2) Divisez le tableau en sous-séquences gauche et droite en une seule passe de tri, de sorte que les éléments de la sous-séquence de gauche soient inférieurs ou égaux à la valeur de l'axe et que les éléments de la sous-séquence de droite soient supérieurs à la valeur de l'axe.
    3) Triez rapidement les sous-séquences gauche et droite de manière récursive jusqu'à ce que la longueur de la séquence soit 1 ou 0.
    4) Obtenez enfin la séquence triée.
  2. Implémentation du tri rapide en Java
    Ce qui suit est un exemple de code pour implémenter le tri rapide en Java :
public class QuickSort {
  public static void quickSort(int[] arr, int low, int high) {
    if (low < high) {
      int pivotIdx = partition(arr, low, high);
      quickSort(arr, low, pivotIdx - 1);
      quickSort(arr, pivotIdx + 1, high);
    }
  }
  
  private static int partition(int[] arr, int low, int high) {
    int pivot = arr[low];
    int i = low + 1;
    int j = high;
    
    while (i <= j) {
      if (arr[i] <= pivot) {
        i++;
      } else if (arr[j] > pivot) {
        j--;
      } else {
        swap(arr, i, j);
      }
    }
    
    swap(arr, low, j);
    
    return j;
  }
  
  private static void swap(int[] arr, int i, int j) {
    int temp = arr[i];
    arr[i] = arr[j];
    arr[j] = temp;
  }
  
  public static void main(String[] args) {
    int[] arr = {5, 2, 9, 1, 3, 7};
    quickSort(arr, 0, arr.length - 1);
    System.out.println(Arrays.toString(arr));
  }
}
Copier après la connexion
  1. Analyse et comparaison des performances
    Pour évaluer les performances de l'algorithme de tri rapide, nous l'avons comparé à plusieurs autres algorithmes de tri courants. Comparer. Vous trouverez ci-dessous un exemple de code qui utilise la méthode System.nanoTime() de Java pour calculer le temps d'exécution d'un algorithme :
import java.util.Arrays;

public class SortComparison {
  public static void main(String[] args) {
    int[] arr = generateArray(10000);
    
    long startTime = System.nanoTime();
    bubbleSort(arr.clone());
    long endTime = System.nanoTime();
    System.out.println("Bubble Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    insertionSort(arr.clone());
    endTime = System.nanoTime();
    System.out.println("Insertion Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    selectionSort(arr.clone());
    endTime = System.nanoTime();
    System.out.println("Selection Sort: " + (endTime - startTime) + " ns");
    
    startTime = System.nanoTime();
    quickSort(arr.clone(), 0, arr.length - 1);
    endTime = System.nanoTime();
    System.out.println("Quick Sort: " + (endTime - startTime) + " ns");
  }
  
  private static int[] generateArray(int size) {
    int[] arr = new int[size];
    for (int i = 0; i < size; i++) {
      arr[i] = (int)(Math.random() * size);
    }
    return arr;
  }
  
  private static void bubbleSort(int[] arr) {
    // 省略冒泡排序的具体实现
  }
  
  private static void insertionSort(int[] arr) {
    // 省略插入排序的具体实现
  }
  
  private static void selectionSort(int[] arr) {
    // 省略选择排序的具体实现
  }
  
  private static void quickSort(int[] arr, int low, int high) {
    // 省略快速排序的具体实现
  }
}
Copier après la connexion

En exécutant le code ci-dessus, nous pouvons obtenir le temps d'exécution de chaque algorithme de tri. Selon les résultats expérimentaux, l’algorithme de tri rapide est généralement plus rapide que le tri à bulles, le tri par insertion et le tri par sélection, en particulier pour trier des ensembles de données à grande échelle. Bien entendu, dans certains cas spécifiques, les performances d'autres algorithmes de tri peuvent être meilleures, c'est pourquoi une analyse spécifique de problèmes spécifiques est effectuée et l'algorithme de tri le plus approprié est sélectionné en fonction de la situation réelle.

Résumé :
Cet article effectue une analyse des performances de l'algorithme de tri rapide en Java et le compare à d'autres algorithmes de tri courants. Grâce à des résultats expérimentaux, nous pouvons conclure que le tri rapide est généralement un algorithme de tri efficace, particulièrement adapté au tri d’ensembles de données à grande échelle. Cependant, pour des problèmes spécifiques, nous devons choisir l’algorithme de tri le plus approprié en fonction de la situation réelle.

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