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 :

Problème de programmation [prolog]


Sujet :

Prolog

  1. #1
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2019
    Messages : 2
    Points : 3
    Points
    3
    Par défaut Problème de programmation [prolog]
    Bonjour bonjour,

    je viens solliciter votre aide car je dois résoudre l'énigme des seaux dans le langage Prolog, j'ai commencé à chercher la solution mais je me retrouve bloqué, et vu le peu d'exemples et d'aides disponibles en ligne je viens demander de l'aide. Voici le problème :

    On considère qu’un état du problème est défini par deux entiers : les contenus des deux seaux. Ecrire le prédicat solution/1 qui détermine la liste des états permettant de passer de [0,0] à un état comprenant la valeur 4. Le résultat est donc une liste de listes à 2 éléments représentant le contenu des deux seaux. Par exemple : [[0,0],[5,0],[2,3],...... [4,0]]. Initialement, cette liste est vide. Les opérations possibles sont :

    - remplir le seau 1 (seau de 5 litres)

    - remplir le seau 2 (seau de 3 litres)

    - vider le seau 1 dans le seau 2 - vider le seau 2 dans le seau 1

    - vider complètement le seau 1

    - vider complètement le seau 2

    a) Ecrire le prédicat solution/1, il fera appel à un prédicat solution/2 qui à partir d’une liste intermédiaire d’états, détermine la liste solution.

    b) Ecrire le prédicat best_solution/1 qui calcule toutes les solutions possibles, affiche le nombre de solutions trouvées, en sélectionne la plus courte et l’affiche

    Voici le code que j'ai fait pour répondre à la première question :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    operation([S1,S2],[5,S2]):- S1=\=5.
    operation([S1,S2],[S1,3]):- S2=\=3.
    operation([S1,S2],[0,S2]):- S1=\=0.
    operation([S1,S2],[S1,0]):- S2=\=0.
    operation([S1,S2],[S3,0]):- S3=<5, S3 is S1+S2.
    operation([S1,S2],[5,S4]):- S4>5, S4 is S1+S2-5.
    operation([S1,S2],[0,S4]):- S4<3, S4 is S1+S2.
    operation([S1,S2],[S3,3]):- S1+S2>3, S3 is S1+S2-3.
     
     
    solution(S,S):-last(S,[4,_]).
    solution(L,S):-last(L,[A,B]), operation([A,B],[S1,S2]),not(memberchk([S1,S2],L)),append(L,[S1,S2],L1),solution(L1,S).
     
    solution(S):- solution([0,0],S).
    Cependant quand je cherche solution(S). Prolog m'affiche "false". Pourriez-vous m'aider?

  2. #2
    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
    Bonjour
    Pour moi :
    remplir le seau 1 (seau de 5 litres) == >
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    remplir_S1([_, Y], [5, Y]).
    le seau 2 n'est pas modifié par cette opération.
    remplir le seau 2 (seau de 3 litres) == >
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    remplir_S2([X, _], [X, 3]).
    le seau 1 n'est pas modifié par cette opération.
    vider le seau 2 dans le seau 1 ==>
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    vider_S2_S1([X0,Y0], [X1,Y1]) :-
        N is 5-X0,
        (   Y0 >= N
        ->  Y1 is Y0-N,
            X1 = 5
        ;   Y1 = 0,
            X1 is X0 + Y0).
    Je vous laisse continuer ...
    "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

  3. #3
    Candidat au Club
    Homme Profil pro
    Étudiant
    Inscrit en
    Mai 2019
    Messages
    2
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 25
    Localisation : France, Isère (Rhône Alpes)

    Informations professionnelles :
    Activité : Étudiant
    Secteur : Enseignement

    Informations forums :
    Inscription : Mai 2019
    Messages : 2
    Points : 3
    Points
    3
    Par défaut
    Merci pour votre réponse mais je ne vois pas bien, ce que ça change par rapport à ce que j'ai mis moi ? :/

  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
    Alors dans ce cas ...
    "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. Problème de programmation orientée objet
    Par dan65 dans le forum WinDev
    Réponses: 8
    Dernier message: 17/09/2006, 01h04
  2. Réponses: 9
    Dernier message: 30/05/2006, 14h57
  3. problème finalisation programme
    Par depelek dans le forum Installation, Déploiement et Sécurité
    Réponses: 9
    Dernier message: 02/05/2006, 16h17
  4. "Philosophie" de la programmation Prolog
    Par Trap D dans le forum Prolog
    Réponses: 2
    Dernier message: 19/01/2006, 13h01
  5. Réponses: 1
    Dernier message: 26/09/2005, 19h29

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