Python - File d'attente
Nous sommes familiers avec la file d'attente dans notre vie quotidienne en attendant un service. La structure de données de la file d'attente signifie également la même chose lorsque les éléments de données sont disposés dans une file d'attente. Le caractère unique de la file d'attente réside dans la manière dont les éléments sont ajoutés et supprimés. Les éléments sont autorisés à la fin mais supprimés de l'autre extrémité. C'est donc une méthode du premier entré, premier sorti. Une file d'attente peut être implémentée en utilisant une liste python où nous pouvons utiliser les méthodes insert () et pop () pour ajouter et supprimer des éléments. Il n'y a pas d'insertion car les éléments de données sont toujours ajoutés à la fin de la file d'attente.
Ajout d'éléments à une file d'attente
Dans l'exemple ci-dessous, nous créons une classe de file d'attente dans laquelle nous implémentons la méthode First-in-First-Out. Nous utilisons la méthode d'insertion intégrée pour ajouter des éléments de données.
class Queue:
def __init__(self):
self.queue = list()
def addtoq(self,dataval):
# Insert method to add element
if dataval not in self.queue:
self.queue.insert(0,dataval)
return True
return False
def size(self):
return len(self.queue)
TheQueue = Queue()
TheQueue.addtoq("Mon")
TheQueue.addtoq("Tue")
TheQueue.addtoq("Wed")
print(TheQueue.size())
Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -
3
Suppression d'un élément d'une file d'attente
Dans l'exemple ci-dessous, nous créons une classe de file d'attente dans laquelle nous insérons les données, puis supprimons les données à l'aide de la méthode pop intégrée.
.class Queue:
def __init__(self):
self.queue = list()
def addtoq(self,dataval):
# Insert method to add element
if dataval not in self.queue:
self.queue.insert(0,dataval)
return True
return False
# Pop method to remove element
def removefromq(self):
if len(self.queue)>0:
return self.queue.pop()
return ("No elements in Queue!")
TheQueue = Queue()
TheQueue.addtoq("Mon")
TheQueue.addtoq("Tue")
TheQueue.addtoq("Wed")
print(TheQueue.removefromq())
print(TheQueue.removefromq())
Lorsque le code ci-dessus est exécuté, il produit le résultat suivant -
Mon
Tue