Table des matières
Description de l'algorithme
Première étape :
Étape 5 :
Implémentation du code
Maison développement back-end Tutoriel Python Comment implémenter l'algorithme de tri Hill en Python

Comment implémenter l'algorithme de tri Hill en Python

May 10, 2023 am 10:25 AM
python

    Description de l'algorithme

    Le tri Hill, également appelé « tri réducteur incrémentiel », est un algorithme de tri produit en optimisant le tri par insertion. Son idée d'exécution est la suivante : regrouper les éléments du tableau en incréments d'indice, insérer et trier chaque groupe d'éléments, réduire l'incrément et répéter les étapes précédentes jusqu'à ce que l'incrément atteigne 1.

    D'une manière générale, la complexité temporelle du tri Hill est O(n1.3)~O(n2), qui dépend de la taille de l'incrément. La complexité spatiale du tri Hill est O(1), qui est un algorithme de tri instable. Lors du tri Hill, un mouvement d'un élément peut s'étendre sur plusieurs éléments, ce qui peut compenser plusieurs mouvements et améliorer l'efficacité.

    Ce qui suit est un tri Hill ascendant utilisant (longueur du tableau/2) comme incrément initial. Après chaque tour de tri, l'incrément est réduit de moitié.

    Première étape :

    Comme le montre la figure 2-28, en commençant par le premier élément, regroupez par incrément de 4. On peut voir que lorsque l'incrément est de 4, il n'y a que deux éléments dans un groupe, sinon l'indice de l'élément dépassera la plage du tableau.

    Comment implémenter lalgorithme de tri Hill en Python

    Étape 2 :

    Comme le montre la figure 2-29, effectuez un tri par insertion sur les éléments du groupe.

    Comment implémenter lalgorithme de tri Hill en Python

    Étape 3 :

    Comme le montre la figure 2-30, continuez à utiliser la même méthode pour regrouper et effectuez un tri par insertion sur les éléments du groupe pour les rendre ordonnés.

    Comment implémenter lalgorithme de tri Hill en Python

    Une fois que tous les nombres de l'ensemble du tableau ont été parcourus, ce tour de tri est terminé. Réduisez l’incrément de moitié et continuez avec le prochain tour de tri.

    Étape 4 :

    Comme le montre la figure 2-31, lorsque l'incrément est de 2, on peut voir que les éléments de chaque groupe ont augmenté et que le nombre total de groupes a diminué. Continuez le tri par insertion des éléments dans chaque groupe jusqu'à ce que chaque groupe soit parcouru.

    Comment implémenter lalgorithme de tri Hill en Python

    Étape 5 :

    Le dernier tour de tri est illustré dans la figure 2-32. Réduisez à nouveau l'incrément de moitié à ce moment, l'incrément est de 1, ce qui équivaut au tri par insertion de l'ensemble du tableau, c'est-à-dire le tri du dernier tour.

    Comment implémenter lalgorithme de tri Hill en Python

    Après le dernier tour de tri, tout le tri Hill est terminé.

    Implémentation du code

    Dans la boucle for, puisque le premier élément de chaque groupe n'a pas besoin d'être inséré et trié et que leurs indices sont compris entre 0 et l'étape 1, le parcours commence à partir de l'étape d'indice.

    Il est à noter que si vous souhaitez simuler l'approche dans l'organigramme, vous devez utiliser deux boucles : d'abord regrouper, puis ordonner les éléments d'un même groupe en une seule fois. Afin d'améliorer l'efficacité, nous utilisons directement une boucle for, et chaque fois qu'un nombre est parcouru, le groupe dans lequel il se trouve est inséré et trié. Ce parcours répond également aux exigences d’ordre du tri par insertion. Dans le tri par insertion, la valeur de l'indice actuel doit être modifiée, donc la variable ind est utilisée pour stocker l'indice actuel afin d'éviter qu'il n'affecte la boucle for.

    Le tri par insertion ordinaire est équivalent au tri Hill avec un incrément de 1. Le tri Hill entre les éléments ne modifie en fait que l'incrément et n'est logiquement pas différent du tri par insertion ordinaire.

    Code de tri des collines :

    nums = [5,3,6,4,1,2,8,7]
    def ShellSort(nums):
      step = len(nums)//2         #初始化增量为数组长度的一半
      while step > 0:           #增量必须是大于0的整数
       for i in range(step,len(nums)): #遍历需要进行插入排序的数
         ind = i
         while ind >= step and nums[ind] < nums[ind-step]: #对每组进行插入排序
          nums[ind],nums[ind-step] = nums[ind-step],nums[ind]
          ind -= step
       step //= 2           #增量缩小一半
      print(nums)
    ShellSort(nums)
    Copier après la connexion

    Exécutez le programme, le résultat de sortie est :

    [1,2,3,4,5,6,7,8]
    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

    AI Hentai Generator

    AI Hentai Generator

    Générez AI Hentai gratuitement.

    Article chaud

    R.E.P.O. Crystals d'énergie expliqués et ce qu'ils font (cristal jaune)
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Meilleurs paramètres graphiques
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    R.E.P.O. Comment réparer l'audio si vous n'entendez personne
    3 Il y a quelques semaines By 尊渡假赌尊渡假赌尊渡假赌
    Où trouver la courte de la grue à atomide atomique
    1 Il y a quelques semaines By DDD

    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)

    La vitesse de conversion est-elle rapide lors de la conversion du XML en PDF sur le téléphone mobile? La vitesse de conversion est-elle rapide lors de la conversion du XML en PDF sur le téléphone mobile? Apr 02, 2025 pm 10:09 PM

    La vitesse du XML mobile à PDF dépend des facteurs suivants: la complexité de la structure XML. Méthode de conversion de configuration du matériel mobile (bibliothèque, algorithme) Méthodes d'optimisation de la qualité du code (sélectionnez des bibliothèques efficaces, optimiser les algorithmes, les données de cache et utiliser le multi-threading). Dans l'ensemble, il n'y a pas de réponse absolue et elle doit être optimisée en fonction de la situation spécifique.

    Comment convertir les fichiers XML en PDF sur votre téléphone? Comment convertir les fichiers XML en PDF sur votre téléphone? Apr 02, 2025 pm 10:12 PM

    Il est impossible de terminer la conversion XML à PDF directement sur votre téléphone avec une seule application. Il est nécessaire d'utiliser les services cloud, qui peuvent être réalisés via deux étapes: 1. Convertir XML en PDF dans le cloud, 2. Accédez ou téléchargez le fichier PDF converti sur le téléphone mobile.

    Quelle est la fonction de la somme du langage C? Quelle est la fonction de la somme du langage C? Apr 03, 2025 pm 02:21 PM

    Il n'y a pas de fonction de somme intégrée dans le langage C, il doit donc être écrit par vous-même. La somme peut être obtenue en traversant le tableau et en accumulant des éléments: Version de boucle: la somme est calculée à l'aide de la longueur de boucle et du tableau. Version du pointeur: Utilisez des pointeurs pour pointer des éléments de tableau, et un résumé efficace est réalisé grâce à des pointeurs d'auto-incitation. Allouer dynamiquement la version du tableau: allouer dynamiquement les tableaux et gérer la mémoire vous-même, en veillant à ce que la mémoire allouée soit libérée pour empêcher les fuites de mémoire.

    Existe-t-il une application mobile qui peut convertir XML en PDF? Existe-t-il une application mobile qui peut convertir XML en PDF? Apr 02, 2025 pm 09:45 PM

    Il n'y a pas d'application qui peut convertir tous les fichiers XML en PDF car la structure XML est flexible et diversifiée. Le noyau de XML à PDF est de convertir la structure des données en une disposition de page, ce qui nécessite l'analyse du XML et la génération de PDF. Les méthodes courantes incluent l'analyse de XML à l'aide de bibliothèques Python telles que ElementTree et la génération de PDF à l'aide de la bibliothèque ReportLab. Pour le XML complexe, il peut être nécessaire d'utiliser des structures de transformation XSLT. Lorsque vous optimisez les performances, envisagez d'utiliser multithread ou multiprocesses et sélectionnez la bibliothèque appropriée.

    Outil de mise en forme XML recommandé Outil de mise en forme XML recommandé Apr 02, 2025 pm 09:03 PM

    Les outils de mise en forme XML peuvent taper le code en fonction des règles pour améliorer la lisibilité et la compréhension. Lors de la sélection d'un outil, faites attention aux capacités de personnalisation, en gérant des circonstances spéciales, des performances et de la facilité d'utilisation. Les types d'outils couramment utilisés incluent des outils en ligne, des plug-ins IDE et des outils de ligne de commande.

    Comment convertir XML en PDF sur votre téléphone? Comment convertir XML en PDF sur votre téléphone? Apr 02, 2025 pm 10:18 PM

    Il n'est pas facile de convertir XML en PDF directement sur votre téléphone, mais il peut être réalisé à l'aide des services cloud. Il est recommandé d'utiliser une application mobile légère pour télécharger des fichiers XML et recevoir des PDF générés, et de les convertir avec des API Cloud. Les API Cloud utilisent des services informatiques sans serveur et le choix de la bonne plate-forme est crucial. La complexité, la gestion des erreurs, la sécurité et les stratégies d'optimisation doivent être prises en compte lors de la gestion de l'analyse XML et de la génération de PDF. L'ensemble du processus nécessite que l'application frontale et l'API back-end fonctionnent ensemble, et il nécessite une certaine compréhension d'une variété de technologies.

    Comment ouvrir le format XML Comment ouvrir le format XML Apr 02, 2025 pm 09:00 PM

    Utiliser la plupart des éditeurs de texte pour ouvrir des fichiers XML; Si vous avez besoin d'un affichage d'arbre plus intuitif, vous pouvez utiliser un éditeur XML, tel que Oxygen XML Editor ou XMLSPY; Si vous traitez les données XML dans un programme, vous devez utiliser un langage de programmation (tel que Python) et des bibliothèques XML (telles que XML.ETREE.ElementTree) pour analyser.

    Comment convertir XML en images Comment convertir XML en images Apr 03, 2025 am 07:39 AM

    XML peut être converti en images en utilisant un convertisseur XSLT ou une bibliothèque d'images. Convertisseur XSLT: Utilisez un processeur XSLT et une feuille de style pour convertir XML en images. Bibliothèque d'images: utilisez des bibliothèques telles que PIL ou ImageMagick pour créer des images à partir de données XML, telles que des formes de dessin et du texte.

    See all articles