Tri à bulle, bug non compris
Résolu
loukimlou
Messages postés
4
Date d'inscription
Statut
Membre
Dernière intervention
-
ellana29460 Messages postés 707 Date d'inscription Statut Membre Dernière intervention -
ellana29460 Messages postés 707 Date d'inscription Statut Membre Dernière intervention -
Bonsoir,
J'ai un programme de tri à bulle à faire en Python. Je sais qu'il y en a des tout faits sur wikipedia ou autre mais je ne les comprend pas (avec True ou False..).
Donc j'ai essayé de le faire par moi-même, mais je suis bloquée par un :
Index Error : List out of range
Je ne peux donc pas aller au bout de mon programme. J'ai essayé de chercher pourquoi ça ne va pas mais je ne comprends pas.. Merci de me dire l'erreur si vous la trouvez.
Ci-joint le screen de mon programme avec l'erreur.
Merci d'avance !

J'ai un programme de tri à bulle à faire en Python. Je sais qu'il y en a des tout faits sur wikipedia ou autre mais je ne les comprend pas (avec True ou False..).
Donc j'ai essayé de le faire par moi-même, mais je suis bloquée par un :
Index Error : List out of range
Je ne peux donc pas aller au bout de mon programme. J'ai essayé de chercher pourquoi ça ne va pas mais je ne comprends pas.. Merci de me dire l'erreur si vous la trouvez.
Ci-joint le screen de mon programme avec l'erreur.
Merci d'avance !

A voir également:
- Fonction tri a bulle
- Fonction si et - Guide
- Comment faire un tri personnalisé sur excel - Guide
- Logiciel tri photo - Guide
- Fonction miroir - Guide
- Fonction moyenne excel - Guide
2 réponses
dans un tableau, les cases sont indexées de 0 à n-1 (pour un tableau de taille n).
la, len(liste)) te retourne n, et donc ta boucle for va tourner pour i allant de 0 à n (compris). le dernier passage va donc se faire hors du tableau, ce qui est une cause de bug.
la solution est donc la suivante :
si tu ne comprend pas mon code, relis le, et si tu ne comprend toujours pas, dis moi ce qui te pose problème dedans
la, len(liste)) te retourne n, et donc ta boucle for va tourner pour i allant de 0 à n (compris). le dernier passage va donc se faire hors du tableau, ce qui est une cause de bug.
la solution est donc la suivante :
def triabulle(liste) for i in range(len(liste)-1) for j in liste if liste[j+1]<liste[j] t=liste[j+1] liste[j+1]=liste[j] #attention : == -> comparaison; = -> affectation liste[j]=t print(liste)
si tu ne comprend pas mon code, relis le, et si tu ne comprend toujours pas, dis moi ce qui te pose problème dedans
ah bah oui, forcément... j'avais cherché les erreurs ce syntaxe, et non les erreurs de logique.
j'ai retrouvé mon code fait en cours en octobre. il est un peu plus complexe mais fonctionne exactement comme le tien :
j'ai retrouvé mon code fait en cours en octobre. il est un peu plus complexe mais fonctionne exactement comme le tien :
import random tab=[] n=int(input("taille du tableau : ")) m=int(input("borne max random : ")) for i in range(n): tab.append(random.randint(1, m)) # je met des nombres au hasard entre 0 et m dans le tableau print(tab) while n>1: # début du tri. une boucle "for" marche tout aussi bien que la boucle "while", c'est juste notre prof qui voulais qu'il utilise le "while" et jamais le "for" i=0 while i<n-1: if tab[i]>tab[i+1]: tmp=tab[i] tab[i]=tab[i+1] tab[i+1]=tmp i+=1 n-=1 input(tab) # affiche le tableau et attend une entrée clavier. permet une pause avant de finir le programme exit()
Merci aussi pour les = et ==.
Cependant ça ne marche toujours pas, j'obtiens exactement la même chose que précédemment..