Comment implémenter un algorithme de tri rapide en utilisant Java
Comment implémenter un algorithme de tri rapide en Java
Quick Sort est un algorithme de tri couramment utilisé et efficace. Son idée de base est d'adopter la stratégie diviser pour régner (Divide and Conquer). En sélectionnant un élément à la fois comme valeur de référence, le tableau à trier est divisé en deux parties, une partie est plus petite que la valeur de référence et l'autre partie est plus grande que la valeur de référence, puis les deux parties sont divisées en deux parties. Effectuez un tri récursif partiel et réalisez enfin le tri de l'ensemble du tableau.
Ci-dessous, nous présenterons en détail comment implémenter l'algorithme de tri rapide à l'aide du langage Java et fournirons des exemples de code spécifiques.
-
Étapes de mise en œuvre de l'algorithme :
- Choisissez une valeur de référence (peut être n'importe quel nombre, choisissez généralement le premier élément du tableau)
- Divisez le tableau en deux parties, et les éléments dans la partie gauche sont tous plus petits) ; que la valeur de référence, les éléments dans la partie droite sont tous supérieurs à la valeur de référence ;
- Triez rapidement les parties gauche et droite de manière récursive ;
- Exemple de code Java :
public class QuickSort { public static void main(String[] args) { int[] arr = {5, 7, 2, 9, 3, 6, 1, 8, 4}; quickSort(arr, 0, arr.length - 1); printArray(arr); } public static void quickSort(int[] arr, int low, int high) { if (low < high) { int pivotIndex = partition(arr, low, high); // 将数组划分为两部分,获取基准值的位置 quickSort(arr, low, pivotIndex - 1); // 递归排序基准值左边的部分 quickSort(arr, pivotIndex + 1, high); // 递归排序基准值右边的部分 } } public static int partition(int[] arr, int low, int high) { int pivot = arr[low]; // 选择数组的第一个元素作为基准值 int left = low + 1; int right = high; while (true) { while (left <= right && arr[left] < pivot) { // 从左往右找到第一个大于或等于基准值的元素 left++; } while (left <= right && arr[right] > pivot) { // 从右往左找到第一个小于或等于基准值的元素 right--; } if (left > right) { break; // 左右指针相遇时退出循环 } swap(arr, left, right); // 交换左右指针指向的元素 } swap(arr, low, right); // 将基准值放回正确的位置 return right; // 返回基准值的位置 } public static void swap(int[] arr, int i, int j) { int temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } public static void printArray(int[] arr) { for (int num : arr) { System.out.print(num + " "); } System.out.println(); } }
-
Analyse des performances :
- Complexité temporelle : la complexité temporelle moyenne du tri rapide est O(nlogn), dans le pire des cas, elle est O(n^2), et dans le pire des cas, c'est O(n^2). Dans de bonnes circonstances, c'est O(n)
- Complexité spatiale : la complexité spatiale du tri rapide est O(logn), en raison de l'espace de pile des appels récursifs.
Grâce à l'introduction ci-dessus, nous avons appris à utiliser le langage Java pour implémenter l'algorithme de tri rapide et compris ses idées de base, ses étapes et son analyse des performances. Le tri rapide est un algorithme de tri couramment utilisé qui peut trier efficacement tout type de données et est particulièrement adapté au tri de données à grande échelle.
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!

Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Guide du nombre parfait en Java. Nous discutons ici de la définition, comment vérifier le nombre parfait en Java ?, des exemples d'implémentation de code.

Guide de Weka en Java. Nous discutons ici de l'introduction, de la façon d'utiliser Weka Java, du type de plate-forme et des avantages avec des exemples.

Guide du nombre de Smith en Java. Nous discutons ici de la définition, comment vérifier le numéro Smith en Java ? exemple avec implémentation de code.

Dans cet article, nous avons conservé les questions d'entretien Java Spring les plus posées avec leurs réponses détaillées. Pour que vous puissiez réussir l'interview.

Java 8 présente l'API Stream, fournissant un moyen puissant et expressif de traiter les collections de données. Cependant, une question courante lors de l'utilisation du flux est: comment se casser ou revenir d'une opération FOREAK? Les boucles traditionnelles permettent une interruption ou un retour précoce, mais la méthode Foreach de Stream ne prend pas directement en charge cette méthode. Cet article expliquera les raisons et explorera des méthodes alternatives pour la mise en œuvre de terminaison prématurée dans les systèmes de traitement de flux. Lire plus approfondie: Améliorations de l'API Java Stream Comprendre le flux Forach La méthode foreach est une opération terminale qui effectue une opération sur chaque élément du flux. Son intention de conception est

Guide de TimeStamp to Date en Java. Ici, nous discutons également de l'introduction et de la façon de convertir l'horodatage en date en Java avec des exemples.

Les capsules sont des figures géométriques tridimensionnelles, composées d'un cylindre et d'un hémisphère aux deux extrémités. Le volume de la capsule peut être calculé en ajoutant le volume du cylindre et le volume de l'hémisphère aux deux extrémités. Ce tutoriel discutera de la façon de calculer le volume d'une capsule donnée en Java en utilisant différentes méthodes. Formule de volume de capsule La formule du volume de la capsule est la suivante: Volume de capsule = volume cylindrique volume de deux hémisphères volume dans, R: Le rayon de l'hémisphère. H: La hauteur du cylindre (à l'exclusion de l'hémisphère). Exemple 1 entrer Rayon = 5 unités Hauteur = 10 unités Sortir Volume = 1570,8 unités cubes expliquer Calculer le volume à l'aide de la formule: Volume = π × r2 × h (4

Spring Boot simplifie la création d'applications Java robustes, évolutives et prêtes à la production, révolutionnant le développement de Java. Son approche "Convention sur la configuration", inhérente à l'écosystème de ressort, minimise la configuration manuelle, allo
