Idées algorithmiques pour implémenter le tri rapide en JavaScript
Cet article présente principalement les idées algorithmiques sur JavaScript pour implémenter un tri rapide. Il a une certaine valeur de référence. Maintenant, je le partage avec vous. Les amis dans le besoin peuvent s'y référer
Actuellement, le tri le plus courant. L'algorithme est probablement Il en existe sept ou huit types, parmi lesquels le « tri rapide » est le plus largement utilisé et le plus rapide. Il a été proposé par Tony Hall (C. A. R. Hoare), lauréat du prix Turing, en 1960.
L'idée du tri rapide est très simple. L'ensemble du processus de tri ne nécessite que trois étapes :
(1) Dans l'ensemble de données, sélectionnez un élément comme "pivot". 🎜 >
(2) Tous les éléments plus petits que "base" sont déplacés vers la gauche de "base" ; tous les éléments plus grands que "base" sont déplacés vers la droite de "base" (3). ) Pour les deux sous-ensembles à gauche et à droite de la "ligne de base", répétez les première et deuxième étapes jusqu'à ce qu'il ne reste plus qu'un seul élément dans tous les sous-ensembles Par exemple, il existe maintenant un ensemble de données {85 ,. 24, 63, 45, 17, 31, 96, 50}, comment les trier ?La première étape consiste à sélectionner l'élément du milieu 45 comme "base" (la valeur de base peut être arbitraire. Choisissez, mais il est plus facile de comprendre de choisir la valeur médiane)
La deuxième étape consiste à comparer chaque élément avec la "ligne de base" afin de former deux sous-ensembles, l'un est "inférieur à 45", et l'autre "supérieur ou égal à 45".
La troisième étape consiste à répéter la première et la deuxième étapes pour les deux sous-ensembles jusqu'à ce qu'il n'y en ait qu'un seul. élément restant dans tous les sous-ensembles Jusqu'à présent
Suivez les étapes précédentes et définissez une fonction quickSort :var quickSort = function(arr) { //参数是一个数组 if (arr.length <= 1) { return arr; } //检查数组的元素个数,如果小于等于1,就返回。 var pivotIndex = Math.floor(arr.length / 2); //选择"基准"(pivot),并将其与原数组分离,再定义两个空数组,用来存放一左一右的两个子集。 var pivot = arr.splice(pivotIndex, 1)[0]; var left = []; var right = []; for (var i = 0; i < arr.length; i++){ //开始遍历数组,小于"基准"的元素放入左边的子集,大于基准的元素放入右边的子集。 if (arr[i] < pivot) { left.push(arr[i]); } else { right.push(arr[i]); } } return quickSort(left).concat([pivot], quickSort(right)); };
- Sélectionnez un élément de la séquence, appelé le "pivot" ;
<🎜 ; >
Réorganisez le tableau de sorte que tous les éléments plus petits que la valeur de base soient placés devant la ligne de base et que tous les éléments plus grands que la valeur de base soient placés derrière la ligne de base (le même nombre peut aller de chaque côté) . Une fois cette partition terminée, la ligne de base sera placée au milieu du tableau. C'est ce qu'on appelle une opération de partition - trie de manière récursive le sous-tableau d'éléments plus petits que la valeur de base. le sous-tableau d'éléments supérieur à la valeur de base ;
- Code d'implémentation :
function quickSort(arr, left, right) { var len = arr.length, partitionIndex, left = typeof left != 'number' ? 0 : left, right = typeof right != 'number' ? len - 1 : right; if (left < right) { partitionIndex = partition(arr, left, right); quickSort(arr, left, partitionIndex-1); quickSort(arr, partitionIndex+1, right); } return arr; } function partition(arr, left ,right) { // 分区操作 var pivot = left, // 设定基准值(pivot) index = pivot + 1; for (var i = index; i <= right; i++) { if (arr[i] < arr[pivot]) { swap(arr, i, index); index++; } } swap(arr, pivot, index - 1); return index-1; } function swap(arr, i, j) { var temp = arr[i]; arr[i] = arr[j]; arr[j] = temp; } function partition2(arr, low, high) { let pivot = arr[low]; while (low < high) { while (low < high && arr[high] > pivot) { --high; } arr[low] = arr[high]; while (low < high && arr[low] <= pivot) { ++low; } arr[high] = arr[low]; } arr[low] = pivot; return low; } function quickSort2(arr, low, high) { if (low < high) { let pivot = partition2(arr, low, high); quickSort2(arr, low, pivot - 1); quickSort2(arr, pivot + 1, high); } return arr; }
Recommandations associées :
Comment trier aléatoirement les tableaux jsjs déplace n'importe quel élément vers une position spécifiéeCe 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

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 !

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)

Sujets chauds





Des questions et des solutions fréquemment posées pour l'impression de billets thermiques frontaux pour le développement frontal, l'impression de billets est une exigence commune. Cependant, de nombreux développeurs mettent en œuvre ...

Il n'y a pas de salaire absolu pour les développeurs Python et JavaScript, selon les compétences et les besoins de l'industrie. 1. Python peut être davantage payé en science des données et en apprentissage automatique. 2. JavaScript a une grande demande dans le développement frontal et complet, et son salaire est également considérable. 3. Les facteurs d'influence comprennent l'expérience, la localisation géographique, la taille de l'entreprise et les compétences spécifiques.

JavaScript est la pierre angulaire du développement Web moderne, et ses principales fonctions incluent la programmation axée sur les événements, la génération de contenu dynamique et la programmation asynchrone. 1) La programmation axée sur les événements permet aux pages Web de changer dynamiquement en fonction des opérations utilisateur. 2) La génération de contenu dynamique permet d'ajuster le contenu de la page en fonction des conditions. 3) La programmation asynchrone garantit que l'interface utilisateur n'est pas bloquée. JavaScript est largement utilisé dans l'interaction Web, les applications à une page et le développement côté serveur, améliorant considérablement la flexibilité de l'expérience utilisateur et du développement multiplateforme.

Comment fusionner les éléments du tableau avec le même ID dans un seul objet en JavaScript? Lors du traitement des données, nous rencontrons souvent la nécessité d'avoir le même ID ...

La discussion sur la réalisation des effets de défilement de parallaxe et d'animation des éléments dans cet article explorera comment réaliser le site officiel de Shiseido (https://www.shiseido.co.jp/sb/wonderland/) ...

Apprendre JavaScript n'est pas difficile, mais c'est difficile. 1) Comprendre les concepts de base tels que les variables, les types de données, les fonctions, etc. 2) Master la programmation asynchrone et les implémenter via des boucles d'événements. 3) Utilisez les opérations DOM et promettez de gérer les demandes asynchrones. 4) Évitez les erreurs courantes et utilisez des techniques de débogage. 5) Optimiser les performances et suivre les meilleures pratiques.

Discussion approfondie des causes profondes de la différence de sortie Console.log. Cet article analysera les différences dans les résultats de sortie de la fonction Console.log dans un morceau de code et expliquera les raisons derrière. � ...

Explorez la mise en œuvre de la fonction de glisser et de réglage du panneau de type VScode dans le frontal. Dans le développement frontal, comment implémenter un VScode comme ...
