Problème de compréhension avec les piles
Résolu
futura2015
Messages postés
40
Date d'inscription
Statut
Membre
Dernière intervention
-
futura2015 Messages postés 40 Date d'inscription Statut Membre Dernière intervention -
futura2015 Messages postés 40 Date d'inscription Statut Membre Dernière intervention -
Bonjour,
Je n'arrive pas à comprendre un exemple sur les piles.
Quelqu'un saurait m'expliquer comment on peut retirer de la même manière les élément un par un jusqu'a ce qu'il n'en reste que deux (donc comme dans l'exemple ci-dessus) mais en augmenter la taille limite à 4 ou à 5 ou à 6 ect... ?
J'espère que je me suis bien exprimée.
Merci d'avance
Je n'arrive pas à comprendre un exemple sur les piles.
MyStack = [] StackSize = 3 def DisplayStack(): print("État courant de la pile :") for Item in MyStack: print(Item) def Push(Value): if len(MyStack) < StackSize: MyStack.append(Value) else: print("La pile est pleine !") def Pop(): if len(MyStack) > 0: MyStack.pop() else: print("La pile est vide.") Push(1) Push(2) Push(3) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") Push(4) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") Pop() DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") Pop() Pop() Pop() DisplayStack()
Quelqu'un saurait m'expliquer comment on peut retirer de la même manière les élément un par un jusqu'a ce qu'il n'en reste que deux (donc comme dans l'exemple ci-dessus) mais en augmenter la taille limite à 4 ou à 5 ou à 6 ect... ?
J'espère que je me suis bien exprimée.
Merci d'avance
A voir également:
- Problème de compréhension avec les piles
- Pile de bios - Guide
- Alcatel f860 mettre les piles ✓ - Forum telephonie fixe
- Piles manette wii - Forum Wii
- Faut il mettre des piles rechargeables dans un téléphone fixe ✓ - Forum Mobile
- Piles de la manette wii ✓ - Forum Bureautique
13 réponses
Bonjour,
La fonction pop retire le dernier élément de la pile.
Pour retirer les éléments un par un jusqu'à ce qu'il n'en reste que deux, tu dois faire une boucle :
tant que la taille de ta pile est strictement supérieure à 2, tu enlèves un élément
Enfin la taille maximum de la pile est définie dans ton exemple par "StackSize" donc si tu veux que ta pile puisse contenir 5 éléments, tu dois mettre cette valeur à 5 :-)
La fonction pop retire le dernier élément de la pile.
Pour retirer les éléments un par un jusqu'à ce qu'il n'en reste que deux, tu dois faire une boucle :
tant que la taille de ta pile est strictement supérieure à 2, tu enlèves un élément
Enfin la taille maximum de la pile est définie dans ton exemple par "StackSize" donc si tu veux que ta pile puisse contenir 5 éléments, tu dois mettre cette valeur à 5 :-)
Bonjour Arya,
Merci pour ta réponse, par contre je ne vois pas ce que ça donne en code tu peux me montrer ?
Merci pour ta réponse, par contre je ne vois pas ce que ça donne en code tu peux me montrer ?
Pour augmenter la taille de la pile (en gardant 5 comme exemple) :
Pour retirer les éléments sauf 2 :
StackSize = 5
Pour retirer les éléments sauf 2 :
def RetirerElements () :
if len(MyStack) < 3 : #on verifie que la pile contient assez d'elements, au moins 3
print ("la pile ne contient pas assez d'elements")
else :
while len (MyStack) > 2 :
MyStack.pop()
Vous n’avez pas trouvé la réponse que vous recherchez ?
Posez votre question
Essaye comme ça moi ça fonctionne
MyStack = [] StackSize = 5 def DisplayStack(): print("État courant de la pile :") for Item in MyStack: print(Item) def Push(Value): if len(MyStack) < StackSize: MyStack.append(Value) else: print("La pile est pleine !") def Pop(): if len(MyStack) > 0: MyStack.pop() else: print("La pile est vide.") def RetirerElements () : if len(MyStack) < 3 : print ("la pile ne contient pas assez d'elements") else : while len (MyStack) > 2 : MyStack.pop() Push(1) Push(2) DisplayStack() RetirerElements () Push(3) Push(4) DisplayStack() RetirerElements () DisplayStack()
Non et puis du coup ca ne marche plus en tapant une touche
État courant de la pile :
1
2
la pile ne contient pas assez d'elements
État courant de la pile :
1
2
3
4
État courant de la pile :
1
2
>>>
ah il faut rajouter les input :
MyStack = [] StackSize = 5 def DisplayStack(): print("État courant de la pile :") for Item in MyStack: print(Item) def Push(Value): if len(MyStack) < StackSize: MyStack.append(Value) else: print("La pile est pleine !") def Pop(): if len(MyStack) > 0: MyStack.pop() else: print("La pile est vide.") def RetirerElements () : if len(MyStack) < 3 : print ("la pile ne contient pas assez d'elements") else : while len (MyStack) > 2 : MyStack.pop() Push(1) Push(2) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") RetirerElements () input("Appuyez sur une touche quand vous êtes prêt...") Push(3) Push(4) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") RetirerElements () DisplayStack()
Explique exactement ce que tu veux alors parce que je dois pas avoir tout compris....
Le programme retire tous les éléments de la pile sauf 2 et ce quel que soit la taille de la pile
Le programme retire tous les éléments de la pile sauf 2 et ce quel que soit la taille de la pile
Alors je vais essayer d'être plus clair.
L'exemple d'origine c'est
qui donne ça
Je souhaiterais qu'en augmentant la taille de la pile, le programme se termine de la même façon,
soit
quelle que soit la taille de la pile.
Hors je n'ai pas réussi à obtenir ce résultat. J'ai augmenté la taille, ajouté des valeurs, modifié le nombre de pop() de la fin, rien n'y fait. Je n'arrive pas à obtenir (exemple avec 4)
Une idée ?
L'exemple d'origine c'est
MyStack = []
StackSize = 3
def DisplayStack():
print("État courant de la pile :")
for Item in MyStack:
print(Item)
def Push(Value):
if len(MyStack) < StackSize:
MyStack.append(Value)
else:
print("La pile est pleine !")
def Pop():
if len(MyStack) > 0:
MyStack.pop()
else:
print("La pile est vide.")
Push(1)
Push(2)
Push(3)
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Push(4)
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Pop()
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Pop()
Pop()
Pop()
DisplayStack()
qui donne ça
État courant de la pile :
1
2
3
Appuyez sur une touche quand vous êtes prêt...
La pile est pleine !
État courant de la pile :
1
2
3
Appuyez sur une touche quand vous êtes prêt...
État courant de la pile :
1
2
Appuyez sur une touche quand vous êtes prêt...
La pile est vide.
État courant de la pile :
>>>
Je souhaiterais qu'en augmentant la taille de la pile, le programme se termine de la même façon,
soit
Appuyez sur une touche quand vous êtes prêt...
État courant de la pile :
1
2
Appuyez sur une touche quand vous êtes prêt...
La pile est vide.
État courant de la pile :
>>>
quelle que soit la taille de la pile.
Hors je n'ai pas réussi à obtenir ce résultat. J'ai augmenté la taille, ajouté des valeurs, modifié le nombre de pop() de la fin, rien n'y fait. Je n'arrive pas à obtenir (exemple avec 4)
État courant de la pile :
1
2
3
4
Appuyez sur une touche quand vous êtes prêt...
La pile est pleine !
État courant de la pile :
1
2
3
4
Appuyez sur une touche quand vous êtes prêt...
État courant de la pile :
1
2
3
Appuyez sur une touche quand vous êtes prêt...
État courant de la pile :
1
2
Appuyez sur une touche quand vous êtes prêt...
La pile est vide.
État courant de la pile :
>>>
Une idée ?
J'ai mieux compris je crois... Et comme ça ?
MyStack = [] StackSize = 5 def DisplayStack(): print("État courant de la pile :") for Item in MyStack: print(Item) def Push(Value): if len(MyStack) < StackSize: MyStack.append(Value) else: print("La pile est pleine !") def Pop(): if len(MyStack) > 0: MyStack.pop() else: print("La pile est vide.") def RetirerElements () : while len (MyStack) > 2 : MyStack.pop() DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") Pop() Pop() Pop() DisplayStack() for i in range (1,StackSize+1) : Push(i) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") Push(StackSize+1) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") RetirerElements () input("Appuyez sur une touche quand vous êtes prêt...") Push(3) Push(4) DisplayStack() input("Appuyez sur une touche quand vous êtes prêt...") RetirerElements () DisplayStack()
Une autre version.
class Fifo(list) : def __init__(self, tmin, tmax, *elements) : self._tmax = tmax self._tmin = tmin super().__init__(elements) self._compteur = super().__len__() if not tmin <= self._compteur <= tmax : raise ValueError("nombre éléments ({}) non compris entre {} et {}".format(self._compteur, tmin, tmax)) def __str__(self) : return super().__str__().replace('\'', '').replace('"', '').strip('[]') def append(self, value) : if self._compteur + 1 > self._tmax : raise RuntimeError("Ne peut ajouter d'élément, la pile est pleine") super().append(value) self._compteur += 1 def pop(self) : if self._compteur - 1 < self._tmin : raise RuntimeError("Ne peut supprimer d'élément, la pile est trop basse") self._compteur -= 1 super().pop(0) @property def compteur(self) : return self._compteur pile = Fifo(0, 4, 'a', 'b', 'c', 'd') print('Première pile') i = 0 while pile.compteur : if i : input('Appuyez sur entrée quand vous êtes prêt...') print('État courant de la pile :') print(pile) pile.pop() i += 1 print('La première pile est vide') print('Seconde pile') pile = Fifo(0, 6) for i in range(1, 7) : pile.append(i) i = 0 while pile.compteur : if i : input('Appuyez sur entrée quand vous êtes prêt...') print('État courant de la pile :') print(pile) pile.pop() i += 1 print('la seconde pile est vide')
Merci j'ai eu la réponse ! :)
c'est :
Il faut rajouter des Pop() dans le code moi je pensais que c'était à la fin alors qu'effectivement c'est logique que ce soit comme ça.
c'est :
MyStack = []
StackSize = 4
def DisplayStack():
print("État courant de la pile :")
for Item in MyStack:
print(Item)
def Push(Value):
if len(MyStack) < StackSize:
MyStack.append(Value)
else:
print("La pile est pleine !")
def Pop():
if len(MyStack) > 0:
MyStack.pop()
else:
print("La pile est vide.")
Push(1)
Push(2)
Push(3)
Push(4)
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Push(5)
Push(6)
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Pop()
DisplayStack()
input("Appuyez sur une touche quand vous êtes prêt...")
Pop()
DisplayStack()
Pop()
Pop()
Pop()
DisplayStack()
Il faut rajouter des Pop() dans le code moi je pensais que c'était à la fin alors qu'effectivement c'est logique que ce soit comme ça.