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

Langage Java Discussion :

Dijkstra : Sommet et Arêtes parcouru


Sujet :

Langage Java

Vue hybride

Message précédent Message précédent   Message suivant Message suivant
  1. #1
    Futur Membre du Club
    Profil pro
    Inscrit en
    Décembre 2009
    Messages
    3
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Décembre 2009
    Messages : 3
    Par défaut Dijkstra : Sommet et Arêtes parcouru
    Bonjour,

    Dans le cadre de mes études, je travaille sur un programme Java sur le métro parisien.
    Le but du programme est d'indiquer les changements pour aller d'un point à un autre.
    J'ai donc 3 classes : arret, ligne (tableau d'arret), reseau(tableau de ligne).
    Dans la classe reseau, j'ai crée une matrice d'incidence du graphe reseau.
    Puis a partir de cette matrice d'incidence j'ai crée une matrice simplifié qui reprend les chemins direct les plus courts entre chaque station. A partir de là j'ai mis en place dijkstra qui me donne donc les distance les plus courts entre chaque station direct ou indirect. Et maintenant j'essaye d'obtenir les arrêts de changements et les lignes.
    J'ai donc bien essayer de mettre en place une liste et de récupérer les arrêts de changements, mais j'ai du mal la placer, vu qu'elle me donne soit n'importe quoi, soit rien (et de temps en temps, la bonne réponse mais c'est du hasard a mon avis...). J'ai aussi essayer pour les lignes mais là non plus je ne sais pas où les placeer. Ci-dessous le code de mon dijkstraArret()

    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
    49
    50
    public int[][][] DijkstraArret(){
    		double [][][] cost = unGrapheSimpleTemps();
    		int[][][] res = new int[cost.length][cost.length][];
    		LinkedList<Integer> liste = new LinkedList<Integer>();
    		boolean [] trouve = new boolean [cost.length];
    		double [] distance = new double [cost.length];
    		for(int s=0; s<cost.length; s++){
    			for (int i=0; i< cost.length; i++){
    				trouve[i]= false;
    				distance[i] = cost[s][i][0];
    			}
    			trouve[s] = true;
    			distance[s]=0;
    			for (int i=0; i< cost.length-1; i++){
    				double minimum=999;
    				int u=-1;
    				for(int j=0; j < cost.length; j++){
    					if(distance[j] < minimum && !trouve[j]){
    						minimum = distance[j];
    						u=j;
    						
    					}
    				}
    				trouve[u] = true;
    				liste.addFirst(u);
    				for (int w=0; w<cost.length; w++){
    					if(!trouve[w] && distance[u]+cost[u][w][0]< distance[w]){
    						distance[w]= distance[u]+cost[u][w][0];
    					}
    				}
    				int compteur=0;
    				LinkedList<Integer> temp = new LinkedList<Integer>(); 
    				while(!(liste.isEmpty())){
    					temp.add(liste.pollFirst());
    					compteur++;
    				}
    				int[] tab= new int[compteur];
    				for (int k=0;k<tab.length;k++){
    					tab[k]=temp.getFirst();
    					temp.removeFirst();
    				}
    				res[s][i]=tab;
    
    
    			}
    
    
    		}
    		return res;
    }

  2. #2
    Membre éclairé
    Homme Profil pro
    NoOb
    Inscrit en
    Mai 2007
    Messages
    554
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France

    Informations professionnelles :
    Activité : NoOb

    Informations forums :
    Inscription : Mai 2007
    Messages : 554
    Par défaut
    Bonjour,

    C'est un peu spaghetti la, difficile d'y voir quelque chose.
    Décompose ton algorithme en fonction simple.
    Je te conseil de mettre des noms de variable clair, et de cibler un peu plus le problème avant de nous le montrer si tu n'arrives pas à le résoudre.

    Sinon pour bien comprendre l'erreur dans ton algo, prends un exemple simple (un changement par exemple) et fait du debug pas a pas.
    tu le fais sur papier en même temps, et tu vas vite tomber sur une ou plusieurs coquilles que tu pourras alors corriger au fur et a mesure.

    HF.

Discussions similaires

  1. Sommet et arêtes
    Par bouritosse dans le forum C++
    Réponses: 13
    Dernier message: 03/11/2014, 18h08
  2. Surfaces, arêtes et sommets
    Par bob53 dans le forum OpenSceneGraph
    Réponses: 3
    Dernier message: 14/05/2012, 11h00
  3. Dijkstra - Sommets et liaisons
    Par Tems2008 dans le forum Windows Forms
    Réponses: 3
    Dernier message: 11/12/2009, 07h37
  4. Calcul du plu court chemin entre 2 sommets d'un graphe valué
    Par atlasm dans le forum Algorithmes et structures de données
    Réponses: 25
    Dernier message: 07/08/2005, 17h06
  5. états de l'art serveurs OLAP ????
    Par greatmaster1971 dans le forum Décisions SGBD
    Réponses: 7
    Dernier message: 17/10/2003, 13h53

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