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

Prolog Discussion :

Algo Listes Prolog


Sujet :

Prolog

  1. #1
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 759
    Points : 208
    Points
    208
    Par défaut Algo Listes Prolog
    bjr à tous et à toutes,
    Voilà je dois étudier Prolog pour un examen professionnel et j'ai du mal à comprendre certains algos dont celui-çi :
    Ce prédicat meme_maison(X,L1,Y,L2) est vrai si X et Y sont dans la même position dans les listes L1 et L2.Les règles donnent ça :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
     
    meme_maison(X,[X|_],Y,[Y|_]). % 1ère règle
    meme_maison(X,[_|L1],Y,[_|L2]):-meme_maison(X,L1,Y,L2). % 2ème règle
    Pour la 1ère règle j'ai pas de problème à la comprendre mais c'est pour la 2ème que j'aimerais qu'un spécialiste me décompose le fonctionnement car j'ai du mal. D'autre part qui connait les commandes sous GNU Prolog pour Windows permettant de déboguer ?
    Merçi

  2. #2
    Membre confirmé
    Femme Profil pro
    Développeur .NET
    Inscrit en
    Avril 2009
    Messages
    339
    Détails du profil
    Informations personnelles :
    Sexe : Femme
    Localisation : France, Marne (Champagne Ardenne)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Avril 2009
    Messages : 339
    Points : 586
    Points
    586
    Par défaut
    Bonjour,

    la deuxième commande signifie que :
    - tu n'es pas entré dans le premier cas, donc X et Y ne sont pas en première position de liste
    - tu fais un appel récursif du prédicat avec les nouvelles listes L1 et L2 en ayant mis de côté le premier élément de chaque liste (X,[_|L1],Y,[_|L2])


    Est-ce que je suis claire ? N'hésite pas à me demander de reformuler.

  3. #3
    Membre actif
    Profil pro
    Inscrit en
    Février 2007
    Messages
    759
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2007
    Messages : 759
    Points : 208
    Points
    208
    Par défaut
    Citation Envoyé par Isythiel Voir le message
    Bonjour,

    la deuxième commande signifie que :
    - tu n'es pas entré dans le premier cas, donc X et Y ne sont pas en première position de liste
    - tu fais un appel récursif du prédicat avec les nouvelles listes L1 et L2 en ayant mis de côté le premier élément de chaque liste (X,[_|L1],Y,[_|L2])


    Est-ce que je suis claire ? N'hésite pas à me demander de reformuler.
    Merçi pour ton aide.
    Si j'ai bien compris grâce au prédicat meme_maison(X,L1,Y,L2) je relance le prédicat meme_maison(X,[_|L1],Y,[_|L2]). en ignorant la 1ère position et avançant pas à pas dans les 2 listes L1 et L2 . Je viens de tester ça marche même si les listes sont de longueur différente.
    Merçi pour ton aide.
    A +

  4. #4
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    pour le debug, je ne connais pas bien Gnu-Prolog, mais tu as à ta disposition les prédicats trace/notrace et debug.
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

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

Discussions similaires

  1. Fusion Liste Prolog
    Par Invité dans le forum Prolog
    Réponses: 2
    Dernier message: 09/06/2009, 23h33
  2. Problème liste Prolog
    Par billouth dans le forum Prolog
    Réponses: 5
    Dernier message: 17/12/2006, 11h28
  3. [Débutant] Notation liste Prolog
    Par guillaume07 dans le forum Prolog
    Réponses: 3
    Dernier message: 23/08/2006, 21h05

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