IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Python Discussion :

Chemin dans un réseau nodal


Sujet :

Python

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre émérite

    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    662
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 662
    Par défaut Chemin dans un réseau nodal
    Bonjour tout le monde,

    Je me suis intéréssé dans le cadre d'un projet personnel à la notion de "graph" telle que présenté ici:
    http://www.python.org/doc/essays/graphs.html

    Je me suis amusé à créer un "réseau" de noeuds reliés entre eux (une seule direction possible, pas de boucle). Le lien ci-dessus présente une méthode pour lister de façon recursive tous les chemins possibles entre deux noeuds.

    Mon soucis c'est que je ne parviens pas à comprendre pleinement l'algorithme employé. Dans l'exemple ci-dessous je créé un graph simple de 10 noeuds et je cherche à connaitre l'essemble des chemins possible entre deux d'entre eux. Le resultat obtenu est correcte, cependant je souhaite sortir non pas une unique liste de tout les noeuds parcouru de tout les chemins possible, mais une liste contenant autant de sous-liste qu'il y a de chemins possibles...

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    20
    21
    22
    23
    24
    25
    26
    27
    28
    29
    30
    31
    32
    33
    34
    35
    36
    37
    38
    39
    40
    41
    42
    43
    44
    45
    46
    47
    48
    class Node(object):
        """ Define a node """
        def __init__(self, value=None):
            self.value = value
     
    def findpaths(graph,start,end,path=[]):
        """ Get a list of all paths between a start and end node 
            Credit: Guido Van Rossum
        """
        path = path + [start]
        if start == end:
            return path
        if not graph.has_key(start):
            return []
        paths = []
        for node in graph[start]:
            if node not in path:
                newpaths = findpaths(graph,node,end,path)
                for newpath in newpaths:
                    paths.append(newpath)
        return paths
     
    # Nodes
    n1 = Node(3)
    n2 = Node(7)
    n3 = Node(4)
    n4 = Node(2)
    n5 = Node(4)
    n6 = Node(6)
    n7 = Node(8)
    n8 = Node(5)
    n9 = Node(9)
    n10 = Node(3)
     
    graph = {n1:[n2,n3], 
             n2:[n4,n5],
             n3:[n5,n6],
             n4:[n7,n8],
             n5:[n8,n9],
             n6:[n9,n10],
             n7:[],
             n8:[],
             n9:[],
             n10:[]}
     
    paths = findpaths(graph,n1,n9)
    print [node.value for node in paths]
    >>[3,7,4,9,3,4,4,9,3,4,6,9]
    Je souhaite en d'autres termes comprendre comment fonctionne l'algo afin d'obtenir ceci:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    [[3,7,4,9],[3,4,4,9],[3,4,6,9]]
    Merci à celui ou celle qui saura m'expliquer!

    Ju

    PS: J'ai bien entendu essayé par moi meme de résoudre mon problem.

  2. #2
    Expert éminent
    Homme Profil pro
    Architecte technique retraité
    Inscrit en
    Juin 2008
    Messages
    21 741
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Manche (Basse Normandie)

    Informations professionnelles :
    Activité : Architecte technique retraité
    Secteur : Industrie

    Informations forums :
    Inscription : Juin 2008
    Messages : 21 741
    Par défaut
    Salut,
    L'algorithme original fonctionne très bien.
    La modification que vous avez apporte ici:
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    def findpaths(graph,start,end,path=[]):
        """ Get a list of all paths between a start and end node 
            Credit: Guido Van Rossum
        """
        path = path + [start]
        if start == end:
            return path   # <---
        if not graph.has_key(start):
            return []
    "casse" la liste de listes.

    - W
    Architectures post-modernes.
    Python sur DVP c'est aussi des FAQs, des cours et tutoriels

  3. #3
    Membre émérite

    Homme Profil pro
    Ingénieur
    Inscrit en
    Août 2010
    Messages
    662
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : Ingénieur
    Secteur : Aéronautique - Marine - Espace - Armement

    Informations forums :
    Inscription : Août 2010
    Messages : 662
    Par défaut
    Merci beaucoup Wiztricks,

    J'étais passé complètement à côté... Je cherchais la solution du côté de la construction de la liste et non de son "renvoi".

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    if start == end:
        return [path]
    Merci encore d'avoir pris le temps de me répondre.


    Ju

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. Calcul de plus court chemin dans un graphe
    Par Elmilouse dans le forum Prolog
    Réponses: 6
    Dernier message: 21/03/2010, 20h26
  2. [JTree] Problème d'ouverture de chemin dans un JTree
    Par antares24 dans le forum Composants
    Réponses: 2
    Dernier message: 11/03/2005, 08h18
  3. Passer en paramètre un chemin dans redirection
    Par croco83 dans le forum ASP
    Réponses: 5
    Dernier message: 07/05/2004, 08h30
  4. Ajouter des chemins dans la variable PATH
    Par Righetto Dominique dans le forum Linux
    Réponses: 7
    Dernier message: 21/03/2004, 17h38
  5. Comment subsituer un chemin par un autre dans un réseau ?
    Par Baillard dans le forum Développement
    Réponses: 3
    Dernier message: 11/08/2002, 14h01

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo