Avec une telle représentation d'un graphe,
la programmation du BFS se réalisera avec une fonction bfs(graphe, sommet de départ)
dont les variables
seront les suivantes :
Déroulement détaillé de la fonction bfs()
data:image/s3,"s3://crabby-images/9060e/9060ee031af132b49e4867b021a93f1d681eb76d" alt="Etape 1" |
P = {'b' : None} Q = ['b'] Découverts(gris ou noirs) = ['b'] Fermés(noirs) = [] |
data:image/s3,"s3://crabby-images/61445/614452a2d67f27a81f7b31eddcc27147bbfb999c" alt="Etape 2" |
P = {'b': None , 'a': 'b' ,
'd': 'b' , 'e': 'b'} Q = ['b', 'a', 'd', 'e'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e'] Fermés(noirs) = [] |
data:image/s3,"s3://crabby-images/2f1a2/2f1a26b8b3ea0a40090e8e4c05042344b9071406" alt="Etape 3" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b'} Q = ['a', 'd', 'e'] Découverts(gris ou noirs) = ['a', 'd', 'e'] Fermés(noirs) = ['b'] |
data:image/s3,"s3://crabby-images/740fb/740fbf1ee99e1f74a35a0cfb089dd08a71f3dc12" alt="Etape 4" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a'} Q = ['d', 'e', 'c'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c'] Fermés(noirs) = ['b', 'a'] |
data:image/s3,"s3://crabby-images/6080f/6080ffdcb198cabe641fdb7b8addf54f40d317f0" alt="Etape 5" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a'} Q = ['e', 'c'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c'] Fermés(noirs) = ['b', 'a', 'd'] |
data:image/s3,"s3://crabby-images/6795f/6795f5bf765c0746f13388c407f8ceff288e4845" alt="Etape 6" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a' , 'f':'e' , 'g':'e'} Q = ['c', 'f', 'g'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g'] Fermés(noirs) = ['b', 'a', 'd', 'e'] |
data:image/s3,"s3://crabby-images/a75ad/a75adaa51a9760b37d58285d76dd7d6620416d1d" alt="Etape 7" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a' , 'f':'e' , 'g':'e'} Q = ['f', 'g'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g'] Fermés(noirs) = ['b', 'a', 'd', 'e', 'c'] |
data:image/s3,"s3://crabby-images/386a9/386a9a989d6e670438bf31e116c0013b575603c8" alt="Etape 8" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a' , 'f':'e' , 'g':'e'} Q = ['g'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g'] Fermés(noirs) = ['b', 'a', 'd', 'e', 'c', 'f'] |
data:image/s3,"s3://crabby-images/aa7f9/aa7f960ddf2906474c0a537490502edc295f88ad" alt="Etape 9" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a , 'f':'e' , 'g':'e' , 'h':'g'} Q = ['h'] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g', 'h'] Fermés(noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g'] |
data:image/s3,"s3://crabby-images/a72f8/a72f86eebf8a6d59808777110144edde3f1e02ab" alt="Etape 10" |
P = {'b':None , 'a':'b' , 'd':'b' , 'e':'b' , 'c':'a' , 'f':'e' , 'g':'e' , 'h':'g'} Q = [] Découverts(gris ou noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g', 'h'] Fermés(noirs) = ['b', 'a', 'd', 'e', 'c', 'f', 'g', 'h'] |
L'arborescence associée au parcours peut donc être modélisée de la façon suivante :
L'ordre de parcours est ligne après ligne et de gauche à droite pour chacune des lignes.
class Maillon:
def __init__(self, valeur, precedent=None, suivant=None):
self.valeur = valeur
self.precedent = precedent
self.suivant = suivant
class File:
def __init__(self):
self.longueur = 0
self.debut = None
self.fin = None
def enfiler(self, valeur):
if self.longueur == 0:
self.debut = self.fin = Maillon(valeur)
else:
self.fin = Maillon(valeur, self.fin)
self.fin.precedent.suivant = self.fin
self.longueur += 1
def defiler(self):
if self.longueur > 0:
valeur = self.debut.valeur
if self.longueur > 1:
self.debut = self.debut.suivant
self.debut.precedent = None
else:
self.debut = self.fin = None
self.longueur -= 1
return valeur
def estVide(self):
return self.longueur == 0
def bfs(G,s) :
P = {s :None}
Q = File()
Q.enfiler(s)
while not(Q.estVide()) :
u = Q.defiler()
for v in G[u] :
if v in P : continue
P[v]=u
Q.enfiler(v)
return P
G = dict()
G['a'] = ['b','c']
G['b'] = ['a','d','e']
G['c'] = ['a','d']
G['d'] = ['b','c','e']
G['e'] = ['b','d','f','g']
G['f'] = ['e','g']
G['g'] = ['e','f','h']
G['h'] = ['g']
P = bfs(G,'b')
print(P)