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

Java Discussion :

récupérer nombre chemins sur un graphe


Sujet :

Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    334
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 334
    Par défaut récupérer nombre chemins sur un graphe
    Bonjour,

    je souhaiterais récupérer le nombre de chemins entre tout couple de sommets sur un graphe. j'utilise l'algo Floyd-Warshall :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
     
     
    //i et j représentent les sommets départ-arrivée et k les sommets intermédiaires
    .........
    for (k = 0; k < n; k++) {
    			for (i = 0; i < n; i++)
    			{
    				for (j = 0; j < n; j++)
    				{
     
    dist[i][j] = Math.min(dist[i][j], dist[i][k] + dist[k][j]);
    ....}
    }
    }
    Comment je pourrais récupérer le nombre de ces chemins?

    Merci.

  2. #2
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Citation Envoyé par flora806 Voir le message
    Comment je pourrais récupérer le nombre de ces chemins?
    Commence par analyser l'algorithme de Floyd-Warshall. Explique clairement ton problème car je ne vois pas la difficulté.
    Quel est pour le moment le résultat de ton programme ?
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  3. #3
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    334
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 334
    Par défaut
    En fait en entrée de mon programme j'ai une matrice n x n qui contient les poids entre 2 sommets (dist[i][j]=..) et mon objectif est à la fois de chercher le chemin le + court entre les couples de sommets mais aussi de récupérer le nombre de chemins qui les relient .

    pour l'instant mon code me permet de récupérer uniquement le poids correspondant au chemin le plus court (dans dist[i][j]) sans le nombre de chemins.

    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
     
    public double[][] getMinLenghts() {
     
    //i et j représentent les sommets départ-arrivée et k les sommets intermédiaires
    .........
     
    // n est le nombre des sommets sur le graphe
     
    for (k = 0; k < n; k++) {
    			for (i = 0; i < n; i++)
    			{
    				for (j = 0; j < n; j++)
    				{
     
    //Algo Floyd Warshall
    dist[i][j] = Math.min(dist[i][j], dist[i][k] + dist[k][j]);
    ....}
    }
    }
     
    return dist;
    }

  4. #4
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Sans réfléchir beaucoup à ton problème, une méthode récursive devrait permettre de calculer le nombre de chemins. Chaque nouveau points est ajouter dans une liste, qui est dupliquée à chaque carrefour. Si le chemin aboutie à l'arrivée, alors tu ranges cette liste dans la liste des chemins possibles. Par contre, il va falloir ajouter des données dans ta matrice pour marquer les points par lesquels tu es déjà passé. Il faut empêcher les cycles infinis.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

  5. #5
    Membre éclairé
    Inscrit en
    Mars 2007
    Messages
    334
    Détails du profil
    Informations forums :
    Inscription : Mars 2007
    Messages : 334
    Par défaut
    Merci pour ta réponse,
    Mais j'ai pas compris, les nouveaux points ce sont les "k"? et c'est quoi le carrefour?

  6. #6
    Membre Expert
    Profil pro
    Inscrit en
    Mai 2004
    Messages
    1 252
    Détails du profil
    Informations personnelles :
    Localisation : Belgique

    Informations forums :
    Inscription : Mai 2004
    Messages : 1 252
    Par défaut
    Attention, ta demande et tes données n'ont pas grand chose en commun.

    Floyd-Warshall permet de découvrir la plus courte distance, tandis que tu désires le nombre de chemins.

    Désires-tu compter les cycles également ?

    Essaie d'utiliser l'API JGraphT, très intéressante pour tes cas.

  7. #7
    Modérateur
    Avatar de dinobogan
    Homme Profil pro
    ingénieur
    Inscrit en
    Juin 2007
    Messages
    4 073
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 44
    Localisation : France

    Informations professionnelles :
    Activité : ingénieur
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Juin 2007
    Messages : 4 073
    Par défaut
    Citation Envoyé par flora806 Voir le message
    Merci pour ta réponse,
    Mais j'ai pas compris, les nouveaux points ce sont les "k"? et c'est quoi le carrefour?
    Les points, ce sont les sommets. Un carrefour est un sommet qui contient plusieurs arcs vers d'autres sommets.
    N'oubliez pas de consulter les FAQ Java et les cours et tutoriels Java
    Que la force de la puissance soit avec le courage de ta sagesse.

Discussions similaires

  1. [MySQL] Récupérer le chemin d'un fichier sur un serveur distant
    Par Blanco68 dans le forum PHP & Base de données
    Réponses: 0
    Dernier message: 12/03/2012, 11h37
  2. Réponses: 3
    Dernier message: 06/12/2010, 15h16
  3. récupérer nombre itérations vers une valeur sur hashmap
    Par flora806 dans le forum Collection et Stream
    Réponses: 2
    Dernier message: 26/02/2008, 14h43
  4. Réponses: 2
    Dernier message: 10/08/2007, 15h05
  5. Nombre de points sur un graphe
    Par Hanae dans le forum BIRT
    Réponses: 5
    Dernier message: 19/07/2007, 11h00

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