Maison Java javaDidacticiel Exemple simple de tri rapide en Java

Exemple simple de tri rapide en Java

Aug 11, 2017 am 09:36 AM
java 示例 简单

Cet article présente principalement en détail des exemples de tri rapide simple Java, qui ont une certaine valeur de référence. Les amis intéressés peuvent s'y référer

1 Concepts de base

Trouver. un élément (en théorie, vous pouvez en trouver n'importe lequel) comme pivot (pivot), puis partitionner le tableau de sorte que la valeur de l'élément sur le côté gauche du pivot ne soit pas supérieure à la valeur du pivot, et la valeur de l'élément sur le côté droit du pivot n'est pas inférieur à La valeur de base, de sorte que l'élément utilisé comme base soit ajusté à la position correcte après le tri. Le tri rapide récursif ajuste les n-1 autres éléments à la position correcte après le tri. Enfin, chaque élément est dans la bonne position après le tri, et le tri est terminé. Par conséquent, l'algorithme de base de l'algorithme de tri rapide est l'opération de partition, c'est-à-dire comment ajuster la position du benchmark et ajuster la position finale du benchmark renvoyé pour la récursion diviser pour régner.

2. Sélectionnez l'élément de référence

1. Correction de l'élément de référence

Si la séquence d'entrée est aléatoire, le temps de traitement est acceptable. Si le tableau est déjà trié, la division à ce moment est une très mauvaise division. Étant donné que chaque division ne peut réduire la séquence à trier que d'une unité, il s'agit du pire des cas. Le tri rapide devient un tri à bulles et la complexité temporelle est Θ (n ^ 2). De plus, il est assez courant que les données d’entrée soient ordonnées ou partiellement ordonnées. Par conséquent, utiliser le premier élément comme élément de base est très mauvais et doit être abandonné immédiatement.

2. Élément de base aléatoire

Il s'agit d'une stratégie relativement sûre. La position de l'élément de référence étant aléatoire, la segmentation résultante ne sera pas toujours une segmentation de mauvaise qualité. Lorsque tous les numéros du tableau sont égaux, c'est toujours le pire des cas et la complexité temporelle est O(n^2). En fait, la probabilité de trier rapidement de manière aléatoire pour obtenir le pire des cas théoriques n'est que de 1/(2^n). Par conséquent, le tri rapide randomisé peut atteindre la complexité temporelle attendue de O(n×log(n)) pour la plupart des données d'entrée.

3. Trouver le milieu de trois nombres

La meilleure division est de diviser la séquence à trier en sous-séquences de longueur égale. Dans le meilleur état, on peut utiliser la valeur médiane du. séquence, c’est-à-dire le N/2ème nombre. Cependant, cela est difficile à calculer et ralentira considérablement le tri rapide. Une telle estimation de la médiane peut être obtenue en sélectionnant aléatoirement trois éléments et en utilisant leur médiane comme élément de base. En fait, le caractère aléatoire n'aide pas beaucoup, donc l'approche générale consiste à utiliser la médiane des trois éléments à l'extrémité gauche, à l'extrémité droite et au centre comme élément de base.

3. Algorithme de partition

L'algorithme de partition est au cœur du tri rapide. Avant d'apprendre le tri rapide, vous pouvez d'abord apprendre cet algorithme. Collez d'abord le code :


  public int partition(int[] num,int left,int right){
    if(num==null || num.length<=0 || left<0 || right>=num.length){
      return 0;
    }
    int prio=num[left+(right-left)/2];  //获取数组中间元素的下标
    while (left<=right){         //从两端交替向中间扫描
      while (num[left]<prio)
        left++;
      while (num[right]>prio)
        right--;
      if (left<=right){
        swap(num,left,right);    //最终将基准数归位 
        left++;
        right--;
      }
    }
    return left;
  }
Copier après la connexion

L'idée de cette méthode est de trouver d'abord un élément pivot (le premier élément se retrouve dans la mise en œuvre de cette méthode, il y a en fait beaucoup de détails) L'article simplifiera la description ici), puis générera deux pointeurs gauche et droit des deux côtés du tableau (l'endroit spécifique où est déterminé par les paramètres transmis à chaque fois que l'on constate que). l'élément de gauche est plus grand que l'élément pivot, je s'arrêtera, et celui de droite le fera. Si l'élément est plus petit que l'élément pivot j, il s'arrête et les positions des deux nombres sont échangées. Jusqu'à ce que les deux pointeurs gauche et droit se rencontrent. Insérez ensuite l'élément pivot dans la position gauche, là où il devrait être.

Le résultat final est de faire apparaître la partie [gauche, droite] du tableau en deux parties. La position finale de l'élément pivot à gauche est inférieure ou égale à l'élément pivot, et la position finale à droite est supérieure ou égale à l'élément pivot. L'élément pivotant est inséré dans une position absolument correcte.

4. Implémentation de l'algorithme de tri


package sort;
/**
 * 快速排序
 * 快速排序采用了分治策略。就是在一个数组中取一个基准数字,把小的数放基准的左边,大的数放基准的右边。
 * 基准左边和右边分别是新的序列。在新的序列中再取一个基准数字,小的放左边,大的放右边。
 * 这个里面用到的递归。我们需要三个参数,一个是数组,另外两个是序列的边界
 * @author HJS
 */
public class QuickSort{

  void sort(int num[],int left,int right){
    if (left
Copier après la connexion

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!

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

Outils d'IA chauds

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Clothoff.io

Clothoff.io

Dissolvant de vêtements AI

Video Face Swap

Video Face Swap

Échangez les visages dans n'importe quelle vidéo sans effort grâce à notre outil d'échange de visage AI entièrement gratuit !

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

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

Nombre parfait en Java Nombre parfait en Java Aug 30, 2024 pm 04:28 PM

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.

Weka en Java Weka en Java Aug 30, 2024 pm 04:28 PM

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.

Numéro de Smith en Java Numéro de Smith en Java Aug 30, 2024 pm 04:28 PM

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.

Questions d'entretien chez Java Spring Questions d'entretien chez Java Spring Aug 30, 2024 pm 04:29 PM

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.

Break or Return of Java 8 Stream Forach? Break or Return of Java 8 Stream Forach? Feb 07, 2025 pm 12:09 PM

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

Horodatage à ce jour en Java Horodatage à ce jour en Java Aug 30, 2024 pm 04:28 PM

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.

Programme Java pour trouver le volume de la capsule Programme Java pour trouver le volume de la capsule Feb 07, 2025 am 11:37 AM

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

PHP vs Python: comprendre les différences PHP vs Python: comprendre les différences Apr 11, 2025 am 12:15 AM

PHP et Python ont chacun leurs propres avantages, et le choix doit être basé sur les exigences du projet. 1.Php convient au développement Web, avec une syntaxe simple et une efficacité d'exécution élevée. 2. Python convient à la science des données et à l'apprentissage automatique, avec une syntaxe concise et des bibliothèques riches.

See all articles