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

Algorithmes et structures de données Discussion :

Graphes et recherche de PCC


Sujet :

Algorithmes et structures de données

  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 4
    Points : 5
    Points
    5
    Par défaut Graphes et recherche de PCC
    J'ai un projet d'étude à faire qui consiste à modéliser la structure d'un réseau de transport d'une ville et de rechercher le PCC entre plusieurs stations.

    J'ai choisi d'utiliser des listes chaînées pour représenter le réseau. Je pense que le réseau comportera une centaine de station.

    Maintenant je réfléchis à l'algorithme à mettre en place pour la recherche des PCC. J'ai le choix entre :
    • Floyd
    • Bellman
    • Dijstra

    Pourrez-vous me dire dans quel cas utiliser quel algo ?

    D'avance, merci

  2. #2
    Expert éminent
    Avatar de PRomu@ld
    Homme Profil pro
    Ingénieur de Recherche
    Inscrit en
    Avril 2005
    Messages
    4 155
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 38
    Localisation : France, Vienne (Poitou Charente)

    Informations professionnelles :
    Activité : Ingénieur de Recherche
    Secteur : Enseignement

    Informations forums :
    Inscription : Avril 2005
    Messages : 4 155
    Points : 6 486
    Points
    6 486
    Par défaut
    Etant donné qu'il s'agit d'un réseau de transport, la solution la plus efficace sera surement Dijkstra. Floyd s'éxécutant en n^3 ça ne devait pas être une bonne idée, sans compter l'espace nécéssaire à l'algorithme.

    Cependant, si le nombre de PCC est grand, il est peut-être envisageable d'utiliser Floyd.

    Mais je ne vois pas en quoi Bellman pourrait être justifié.

  3. #3
    Futur Membre du Club
    Profil pro
    Inscrit en
    Mai 2007
    Messages
    4
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France

    Informations forums :
    Inscription : Mai 2007
    Messages : 4
    Points : 5
    Points
    5
    Par défaut
    Je n'arrive pas à mettre la main sur la complexité spaciale de Dijkstra et d'autres algo (Floyd-Warshall, Bellman, Fords-Fulkerson et MKM).

    Parceque qu'au niveau de la complexité temporelle, c'est bien Dijkstra qui semble l'emporter de loin, mais au niveau de la complexité spaciale je ne trouve rien ...

  4. #4
    Membre régulier
    Profil pro
    Conseil - Consultant en systèmes d'information
    Inscrit en
    Juillet 2004
    Messages
    89
    Détails du profil
    Informations personnelles :
    Localisation : France, Bas Rhin (Alsace)

    Informations professionnelles :
    Activité : Conseil - Consultant en systèmes d'information

    Informations forums :
    Inscription : Juillet 2004
    Messages : 89
    Points : 106
    Points
    106
    Par défaut
    Sans compter le stockage du graphe:

    Pour Floyd (ou Roy-Warshall, ou Roy-Floyd, ou encore Floyd-Warshall...), tu as besoin d'une matrice pour stocker le plus court chemin entre chaque paires de points, donc N^2 en mémoire.
    Pour Dijkstra t'as un tas qui contient au max N élements (les noeuds ainsi que la distance au départ). Par contre uniquement si tu peux mettre à jour un élément dedans, sinon tu replaces à chaque fois et tu montes aussi à N^2.
    Pour Bellman-Ford tu dois stocker la distance entre le départ et chaque noeud, donc en N.

  5. #5
    Membre confirmé
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    327
    Détails du profil
    Informations personnelles :
    Localisation : France, Bouches du Rhône (Provence Alpes Côte d'Azur)

    Informations forums :
    Inscription : Mai 2004
    Messages : 327
    Points : 487
    Points
    487
    Par défaut
    Bellman est utile pour traiter le cas d'arcs à valuation négative. Dijkstra est le plus simple à utiliser mais il ne te donne le pcc vers les autres ommets de ton graphe pour un seul point donné.
    Floyd te permet de calculer un dsitancier car il fait le travail du calcil des pcc pour tous les sommets de ton graphe. C'est "comme si" tu utilisais Dijkstra "en boucle". Mais Floyd est le plus adapté pour un distancier.

Discussions similaires

  1. [Graphes conceptuels] Recherche d'Hom(G,H) (problème de la coloration-H)
    Par SpiceGuid dans le forum Intelligence artificielle
    Réponses: 0
    Dernier message: 07/12/2011, 17h12
  2. A* , graphe , arbre de recherche
    Par guillaume07 dans le forum Algorithmes et structures de données
    Réponses: 13
    Dernier message: 27/08/2006, 21h28
  3. Réponses: 3
    Dernier message: 09/05/2006, 19h06
  4. recherche du plus cours chemins entre 2 sommets d'1 graphes
    Par must19 dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 05/04/2006, 11h57
  5. Recherche bibliothèques de graphes
    Par Frecktel dans le forum Bibliothèques
    Réponses: 10
    Dernier message: 12/01/2006, 17h14

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