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

C Discussion :

Heuristique voyageur de commerce


Sujet :

C

  1. #1
    Membre à l'essai
    Profil pro
    Inscrit en
    Mars 2008
    Messages
    36
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Mars 2008
    Messages : 36
    Points : 15
    Points
    15
    Par défaut Heuristique voyageur de commerce
    Bonjour à tous,

    J'implémente en C une heuristique du voyageur de commerce dans laquelle je dois limité la recherche au k villes les plus proches non visités, j'ai tenter une premiere approche , je souhaiterez que vous me disiez ce que vous en pensez, est ce que cela semble réalisable, je n'ai volontairement pas tout implémenté, le code est commenté:
    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
    51
    52
    53
    54
    55
    56
     
    #include <stdio.h>
    #include <stdlib.h>
     
    #define NB_VILLES 5
     
    static int k=3;
    static chemin chemin_mini;
     
    struct chemin{
      int * chemin;
      int dstance;
    };
     
    struct parcours{
      int * chemin;
      int niveau;
    };
     
    typedef struct parcours * parcours;
    typedef struct chemin *chemin;
    typedef bool * villeVisite;
     
    void parcours(parcour p, villeVisite v){ 
     
     if(p->niveau == NB_VILLES){ //Si le parcours est rempli...
       int dp=distanceParcours(p); //... on calcule sa distance
       if(dp < chemin_mini->distance)//si elle est inferieure a la distance du chemin_mini
         {
           chemin_mini->chemin = p->chemin; //on la sauve
           chemin_mini->distance = dp;// et sa distance aussi
         }
       }
     
       else{ //Sinon c'est qu'il est pas rempli
         int * vpp=kVillesPlusProches(p->chemin[niveau], v); // on récupere dans un tableau les k villes les plus proches de la derniere ville
         for(int i=0; i < k; i++){
           villeVisite v_i=coche(v, vpp[i]); //on cochera la ville que l'on viste dans le tableau de booleen
           parcours p_i=ajouterParcours(p, vpp[i]); //on la rajoute en fin de parcours
           parcours(p_i, v_i);// et on lance les appels récursif
           liberer(v_i, p_i); // on les liberera
         }
       }
    }
     
     
    int main(void){
      int ville_de_depart=0;
      parcours p=parcoursCreer(ville_de_depart, NB_VILLES);
      villeVisite v=villeVisiteCreer(NB_VILLES);
      coche(v,0);
     
      parcours(p,v);
     
      affiche(chemin_mini);
    }

  2. #2
    Modérateur
    Avatar de ToTo13
    Homme Profil pro
    Chercheur en informatique
    Inscrit en
    Janvier 2006
    Messages
    5 793
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 45
    Localisation : Etats-Unis

    Informations professionnelles :
    Activité : Chercheur en informatique
    Secteur : Santé

    Informations forums :
    Inscription : Janvier 2006
    Messages : 5 793
    Points : 9 860
    Points
    9 860
    Par défaut
    Bonjour,

    en général, pur chaque ville, il suffit de trier les villes voisines en fonction de la distance, puis de ne parcourir que les K plus proches.
    Consignes aux jeunes padawans : une image vaut 1000 mots !
    - Dans ton message respecter tu dois : les règles de rédaction et du forum, prévisualiser, relire et corriger TOUTES les FAUTES (frappes, sms, d'aurteaugrafe, mettre les ACCENTS et les BALISES) => ECRIRE clairement et en Français tu DOIS.
    - Le côté obscur je sens dans le MP => Tous tes MPs je détruirai et la réponse tu n'auras si en privé tu veux que je t'enseigne.(Lis donc ceci)
    - ton poste tu dois marquer quand la bonne réponse tu as obtenu.

Discussions similaires

  1. Réponses: 2
    Dernier message: 24/11/2009, 18h08
  2. Probleme Voyageur de Commerce - Recuit Simulé
    Par dinver dans le forum Algorithmes et structures de données
    Réponses: 4
    Dernier message: 21/06/2009, 22h26
  3. Algo heuristique voyageur de commerce
    Par tagsOf dans le forum Algorithmes et structures de données
    Réponses: 9
    Dernier message: 25/03/2008, 13h44
  4. Voyageur de commerce, mais en plus compliqué
    Par Krispy dans le forum Algorithmes et structures de données
    Réponses: 18
    Dernier message: 16/02/2004, 08h44
  5. Voyageur de commerce
    Par senke dans le forum Algorithmes et structures de données
    Réponses: 8
    Dernier message: 27/09/2002, 12h51

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